

# V850E/PHC3

32-bit Single-Chip Microcontroller

µPD70F3485

All information contained in these materials, including products and product specifications, represents information on the product at the time of publication and is subject to change by Renesas Electronics Corp. without notice. Please review the latest information published by Renesas Electronics Corp. through various means, including the Renesas Electronics Corp. website (http://www.renesas.com).

Renesas Electronics www.renesas.com R01UH0120ED0220, Rev. 2.20 December 12, 2013

32

# Notice

- All information included in this document is current as of the date this document is issued. Such information, however, is subject to change without any prior notice. Before purchasing or using any Renesas Electronics products listed herein, please confirm the latest product information with a Renesas Electronics sales office. Also, please pay regular and careful attention to additional and different information to be disclosed by Renesas Electronics such as that disclosed through our website.
- 2. Renesas Electronics does not assume any liability for infringement of patents, copyrights, or other intellectual property rights of third parties by or arising from the use of Renesas Electronics products or technical information described in this document. No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights of Renesas Electronics or others.
- 3. You should not alter, modify, copy, or otherwise misappropriate any Renesas Electronics product, whether in whole or in part.
- 4. Descriptions of circuits, software and other related information in this document are provided only to illustrate the operation of semiconductor products and application examples. You are fully responsible for the incorporation of these circuits, software, and information in the design of your equipment. Renesas Electronics assumes no responsibility for any losses incurred by you or third parties arising from the use of these circuits, software, or information.
- 5. When exporting the products or technology described in this document, you should comply with the applicable export control laws and regulations and follow the procedures required by such laws and regulations. You should not use Renesas Electronics products or the technology described in this document for any purpose relating to military applications or use by the military, including but not limited to the development of weapons of mass destruction. Renesas Electronics products and technology may not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited under any applicable domestic or foreign laws or regulations.
- 6. Renesas Electronics has used reasonable care in preparing the information included in this document, but Renesas Electronics does not warrant that such information is error free. Renesas Electronics assumes no liability whatsoever for any damages incurred by you resulting from errors in or omissions from the information included herein.
- 7. Renesas Electronics products are classified according to the following three quality grades: "Standard", "High Quality", and "Specific". The recommended applications for each Renesas Electronics product depends on the product's quality grade, as indicated below. You must check the quality grade of each Renesas Electronics product before using it in a particular application. You may not use any Renesas Electronics product for any application categorized as "Specific" without the prior written consent of Renesas Electronics. Further, you may not use any Renesas Electronics shall not be in any way liable for any damages or losses incurred by you or third parties arising from the use of any Renesas Electronics product for an application categorized as "Specific" or for which the product is not intended where you have failed to obtain the prior written consent of Renesas Electronics.



The quality grade of each Renesas Electronics product is "Standard" unless otherwise expressly specified in a Renesas Electronics data sheets or data books, etc.

- "Standard": Computers; office equipment; communications equipment; test and measurement equipment; audio and visual equipment; home electronic appliances; machine tools; personal electronic equipment; and industrial robots.
  "High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control systems; anti-disaster systems; anti-crime systems; safety equipment; and medical equipment not specifically designed for life support.
  "Specific": Aircraft; aerospace equipment; submersible repeaters; nuclear reactor control systems; medical equipment or systems for life support (e.g. artificial life support devices or systems), surgical implantations, or healthcare intervention (e.g. excision, etc.), and any other applications or purposes that pose a direct threat to human life.
- 8. You should use the Renesas Electronics products described in this document within the range specified by Renesas Electronics, especially with respect to the maximum rating, operating supply voltage range, movement power voltage range, heat radiation characteristics, installation and other product characteristics. Renesas Electronics shall have no liability for malfunctions or damages arising out of the use of Renesas Electronics products beyond such specified ranges.
- 9. Although Renesas Electronics endeavors to improve the quality and reliability of its products, semiconductor products have specific characteristics such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Further, Renesas Electronics products are not subject to radiation resistance design. Please be sure to implement safety measures to guard them against the possibility of physical injury, and injury or damage caused by fire in the event of the failure of a Renesas Electronics product, such as safety design for hardware and software including but not limited to redundancy, fire control and malfunction prevention, appropriate treatment for aging degradation or any other appropriate measures. Because the evaluation of microcomputer software alone is very difficult, please evaluate the safety of the final products or system manufactured by you.
- 10. Please contact a Renesas Electronics sales office for details as to environmental matters such as the environmental compatibility of each Renesas Electronics product. Please use Renesas Electronics products in compliance with all applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive. Renesas Electronics assumes no liability for damages or losses occurring as a result of your noncompliance with applicable laws and regulations.
- 11. This document may not be reproduced or duplicated, in any form, in whole or in part, without prior written consent of Renesas Electronics.
- 12. Please contact a Renesas Electronics sales office if you have any questions regarding the information contained in this document or Renesas Electronics products, or if you have any other inquiries.
- (Note 1) "Renesas Electronics" as used in this document means Renesas Electronics Corporation and also includes its majority-owned subsidiaries.
- (Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics.



# **General Precautions in the Handling of MPU/MCU Products**

The following usage notes are applicable to all MPU/MCU products from Renesas. For detailed usage notes on the products covered by this manual, refer to the relevant sections of the manual. If the descriptions under General Precautions in the Handling of MPU/MCU Products and in the body of the manual differ from each other, the description in the body of the manual takes precedence.

1. Handling of unused Pins

Handle unused pins in accord with the directions given under Handling of Unused Pins in the manual.

- The input pins of CMOS products are generally in the high-impedance state. In operation with an unused pin in the open-circuit state, extra electromagnetic noise is induced in the vicinity of LSI, an associated shoot-through current flows internally, and malfunctions occur due to the false recognition of the pin state as an input signal become possible. Unused pins should be handled as described under Handling of Unused Pins in the manual.
- 2. Processing at power-on

The state of the product is undefined at the moment when power is supplied.

- The states of internal circuits in the LSI are indeterminate and the states of register settings and pins are undefined at the moment when power is supplied.

In a finished product where the reset signal is applied to the external reset pin, the states of pins are not guaranteed from the moment when power is supplied until the reset process is completed.

In a similar way, the states of pins in a product that is reset by an on-chip power-on reset function are not guaranteed from the moment when power is supplied until the power reaches the level at which resetting has been specified.

3. Prohibition of access to reserved addresses

Access to reserved addresses is prohibited.

- The reserved addresses are provided for the possible future expansion of functions. Do not access these addresses; the correct operation of LSI is not guaranteed if they are accessed.
- 4. Clock signals

After applying a reset, only release the reset line after the operating clock signal has become stable. When switching the clock signal during program execution, wait until the target clock signal has stabilized.

- When the clock signal is generated with an external resonator (or from an external oscillator) during a reset, ensure that the reset line is only released after full stabilization of the clock signal. Moreover, when switching to a clock signal produced with an external resonator (or by an external oscillator) while program execution is in progress, wait until the target clock signal is stable.
- 5. Differences between products

Before changing from one product to another, i.e. to one with a different part number, confirm that the change will not lead to problems.

 The characteristics of MPU/MCU in the same group but having different part numbers may differ because of the differences in internal memory capacity and layout pattern. When changing to products of different part numbers, implement a system-evaluation test for each of the products.



# Preface

| Readers                                             | This manual is intended for u concerned microcontrollers.                                                                                                                                                                                                                                                     | sers who want to understand the functions of the                                                                                                                                                                                                                                                   |
|-----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Purpose                                             | This manual presents the ha                                                                                                                                                                                                                                                                                   | rdware manual for the concerned microcontrollers.                                                                                                                                                                                                                                                  |
| Organization                                        | <ul><li>This system specification des</li><li>Pin function</li><li>CPU function</li><li>Internal peripheral function</li></ul>                                                                                                                                                                                | scribes the following sections:                                                                                                                                                                                                                                                                    |
| Module instances                                    | In general the different instar                                                                                                                                                                                                                                                                               | contain several instances of a dedicated module.<br>nces of such modules are identified by the index<br>to the number of instances minus one.                                                                                                                                                      |
| Legend                                              | Symbols and notation are us                                                                                                                                                                                                                                                                                   | ed as follows:                                                                                                                                                                                                                                                                                     |
|                                                     | Weight in data notation:                                                                                                                                                                                                                                                                                      | Left is high order column, right is low order column                                                                                                                                                                                                                                               |
|                                                     | Active low notation:                                                                                                                                                                                                                                                                                          | xxx (pin or signal name is over-scored) or<br>/xxx (slash before signal name)                                                                                                                                                                                                                      |
|                                                     | Memory map address:                                                                                                                                                                                                                                                                                           | High order at high stage and low order at low stage                                                                                                                                                                                                                                                |
| Note                                                | Additional remark or tip                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                    |
|                                                     |                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                    |
| Caution                                             | Item deserving extra attentio                                                                                                                                                                                                                                                                                 | n                                                                                                                                                                                                                                                                                                  |
| Caution Numeric notation:                           |                                                                                                                                                                                                                                                                                                               | n<br>xxxx or xxx <sub>B</sub>                                                                                                                                                                                                                                                                      |
|                                                     | Item deserving extra attentio<br>• Binary:<br>• Decimal:                                                                                                                                                                                                                                                      | xxxx or xxx <sub>B</sub><br>xxxx                                                                                                                                                                                                                                                                   |
| Numeric notation:                                   | Item deserving extra attentio<br>• Binary:<br>• Decimal:<br>• Hexadecimal:                                                                                                                                                                                                                                    | xxxx or xxx <sub>B</sub><br>xxxx<br>xxxx <sub>H</sub> or 0x xxxx                                                                                                                                                                                                                                   |
|                                                     | Item deserving extra attentio<br>• Binary:<br>• Decimal:<br>• Hexadecimal:<br>representing powers of 2 (ad                                                                                                                                                                                                    | xxxx or xxx <sub>B</sub><br>xxxx<br>xxxx <sub>H</sub> or 0x xxxx<br>dress space, memory capacity):                                                                                                                                                                                                 |
| Numeric notation:                                   | Item deserving extra attentio<br>• Binary:<br>• Decimal:<br>• Hexadecimal:<br>representing powers of 2 (ad<br>• K (kilo):                                                                                                                                                                                     | xxxx or xxx <sub>B</sub><br>xxxx<br>xxxx <sub>H</sub> or 0x xxxx<br>dress space, memory capacity):<br>$2^{10} = 1024$                                                                                                                                                                              |
| Numeric notation:                                   | Item deserving extra attentio<br>• Binary:<br>• Decimal:<br>• Hexadecimal:<br>representing powers of 2 (ad                                                                                                                                                                                                    | xxxx or xxx <sub>B</sub><br>xxxx<br>xxxx <sub>H</sub> or 0x xxxx<br>dress space, memory capacity):                                                                                                                                                                                                 |
| Numeric notation:                                   | Item deserving extra attentio<br>• Binary:<br>• Decimal:<br>• Hexadecimal:<br>representing powers of 2 (ad<br>• K (kilo):<br>• M (mega):                                                                                                                                                                      | xxxx or xxx <sub>B</sub><br>xxxx<br>xxxx <sub>H</sub> or 0x xxxx<br>dress space, memory capacity):<br>$2^{10} = 1024$<br>$2^{20} = 1024^{2} = 1,048,576$                                                                                                                                           |
| Numeric notation:<br>Prefixes                       | <ul> <li>Item deserving extra attentio</li> <li>Binary:</li> <li>Decimal:</li> <li>Hexadecimal:</li> <li>representing powers of 2 (ad</li> <li>K (kilo):</li> <li>M (mega):</li> <li>G (giga):</li> <li>X, x = don't care</li> </ul>                                                                          | xxxx or xxx <sub>B</sub><br>xxxx<br>xxxx <sub>H</sub> or 0x xxxx<br>dress space, memory capacity):<br>$2^{10} = 1024$<br>$2^{20} = 1024^{2} = 1,048,576$                                                                                                                                           |
| Numeric notation:<br>Prefixes<br>Register contents: | <ul> <li>Item deserving extra attention</li> <li>Binary: <ul> <li>Decimal:</li> <li>Hexadecimal:</li> <li>representing powers of 2 (ad</li> <li>K (kilo):</li> <li>M (mega):</li> <li>G (giga):</li> </ul> </li> <li>X, x = don't care</li> <li>Block diagrams do not necess functional structure.</li> </ul> | xxxx or xxx <sub>B</sub><br>xxxx<br>xxxx <sub>H</sub> or 0x xxxx<br>dress space, memory capacity):<br>$2^{10} = 1024$<br>$2^{20} = 1024^2 = 1,048,576$<br>$2^{30} = 1024^3 = 1,073,741,824$<br>assarily show the exact wiring in hardware but the<br>tional explanation purposes only, without any |



SuperFlash<sup>(R)</sup> SuperFlash<sup>(R)</sup> is a registered trademark of Silicon Storage Technology, Inc. in several countries including the United States and Japan.

This product uses  $\mathsf{SuperFlash}^{(\mathsf{R})}$  technology licensed from Silicon Technology, Inc.



# **Table of Contents**

| Table of Contents   7 |         |                                  |    |
|-----------------------|---------|----------------------------------|----|
| Chap                  | ter 1   | Introduction                     | 17 |
| 1.1                   |         | I                                |    |
|                       |         |                                  |    |
| 1.2                   |         | es Summary                       |    |
| 1.3                   | •       | otion                            |    |
|                       | 1.3.1   | Internal units                   |    |
|                       | 1.3.2   | Structure of the manual          | 22 |
| Chap                  | ter 2   | Pin Functions                    | 23 |
| 2.1                   | Overvie | ew                               | 23 |
|                       | 2.1.1   | Description                      | 24 |
|                       | 2.1.2   | Terms                            | 26 |
|                       | 2.1.3   | Noise elimination                | 26 |
| 2.2                   | Port Gr | oup Configuration Registers      | 27 |
|                       | 2.2.1   | Overview                         |    |
|                       | 2.2.2   | Pin function configuration       |    |
|                       | 2.2.3   | Pin data input/output            |    |
|                       | 2.2.4   | Emergency shut-off configuration |    |
|                       | 2.2.5   | Write enable register            |    |
| 2.3                   |         | oup Configuration                |    |
|                       | 2.3.1   | Port group configuration lists.  |    |
|                       | 2.3.2   | Non-port pins.                   |    |
|                       | 2.3.3   | Port Types Diagrams              |    |
|                       | 2.3.4   | Alphabetic pin function list.    |    |
|                       | 2.3.5   | Port group 0                     |    |
|                       | 2.3.6   | Port group 1                     |    |
|                       | 2.3.7   | Port group 2                     |    |
|                       | 2.3.8   | Port group 3                     |    |
|                       | 2.3.9   | Port group 4                     |    |
|                       | 2.3.10  | Port group 5                     |    |
|                       | 2.3.11  | Port group 6                     |    |
|                       | 2.3.12  | Port group 7                     |    |
|                       | 2.3.12  | Port group 8                     |    |
|                       | 2.3.14  | Port group 9                     |    |
|                       | 2.3.15  | Port group 10                    |    |
|                       | 2.3.16  | Port group 11                    |    |
| 2.4                   |         |                                  |    |
| 2.7                   | 2.4.1   | Analog filtered inputs.          |    |
|                       | 2.4.2   | Digitally filtered inputs        |    |
| 2.5                   |         | nctions during and after Reset   |    |
| 2.5<br>2.6            |         | mended Connection of unused Pins |    |
| 2.0                   |         |                                  |    |
| 2.1                   | гаскау  | e Pins Assignment                | 09 |
| Chap                  | ter 3   | CPU System Functions             | 71 |
| 3.1                   |         | e                                |    |
| 5.1                   | 3.1.1   |                                  |    |
|                       | 3.1.1   | ບຣະເກຍແບກ                        | 12 |



| 3.2  | CPU R          | egister Set                                  | 73  |
|------|----------------|----------------------------------------------|-----|
|      | 3.2.1          | General purpose registers (r0 to r31)        | 74  |
|      | 3.2.2          | System register set                          | 75  |
|      | 3.2.3          | Floating-point arithmetic registers          | 82  |
| 3.3  | Operat         | ion Modes                                    | 84  |
|      | 3.3.1          | Normal operation mode                        | 84  |
|      | 3.3.2          | Flash programming mode                       | 84  |
| 3.4  | Addres         | ss Space                                     | 85  |
|      | 3.4.1          | CPU address space and physical address space | 85  |
|      | 3.4.2          | Program and data space                       | 87  |
| 3.5  |                | <b>y</b>                                     |     |
|      | 3.5.1          | Memory areas                                 |     |
| 3.6  |                | CC error detection                           |     |
|      | 3.6.1          | RAM ECC initialization                       |     |
|      | 3.6.2          | RAM ECC registers.                           |     |
|      | 3.6.3          | RAM ECC function check                       |     |
|      | 3.6.4          | Recommended use of data address space        |     |
| 3.7  | Write F        | Protected Registers.                         | 97  |
| Char | tor A          | Interview Controller (INTC)                  |     |
| Chap |                | Interrupt Controller (INTC)                  |     |
| 4.1  |                | es                                           |     |
| 4.2  |                | askable Interrupts                           |     |
|      | 4.2.1          | Operation                                    |     |
|      | 4.2.2          | Restore                                      |     |
|      | 4.2.3          | Non-maskable interrupt status flag (NP)      |     |
|      | 4.2.4          |                                              |     |
| 4.3  |                | ble Interrupts                               |     |
|      | 4.3.1<br>4.3.2 | Operation                                    |     |
|      | 4.3.2<br>4.3.3 |                                              |     |
|      | 4.3.3<br>4.3.4 | Priorities of maskable interrupts            |     |
|      | 4.3.4<br>4.3.5 | IMR0 to IMR7 - Interrupt mask registers      |     |
|      | 4.3.5          | ISPR - In-service priority register          |     |
|      | 4.3.0          | Maskable interrupt status flag (ID)          |     |
|      | 4.3.8          | External maskable interrupts.                |     |
| 4.4  |                | nd Level Detection Configuration             |     |
| 4.5  | -              | pt Sharing                                   |     |
| 4.6  |                | re Exception                                 |     |
|      | 4.6.1          | Operation                                    |     |
|      | 4.6.2          | Restore                                      |     |
|      | 4.6.3          | Exception status flag (EP)                   |     |
| 4.7  |                | ion Trap.                                    |     |
|      | 4.7.1          | Illegal opcode definition                    |     |
|      | 4.7.2          | Debug trap                                   |     |
| 4.8  |                | e Interrupt Processing Control.              |     |
| 4.9  |                | pt Response Time                             |     |
| 4.10 |                | s in Which Interrupts Are Not Acknowledged   |     |
|      |                |                                              |     |
| Chap | ter 5          | CRC Function (CRC)                           | 142 |

R01UH0120ED0220 Rev. 2.20 User Manual

RENESAS

| 5.1        | Featur  | es                                               | 142 |
|------------|---------|--------------------------------------------------|-----|
|            | 5.1.1   | DATA-CRC                                         | 142 |
| 5.2        | Config  | juration                                         | 143 |
| 5.3        | CRC R   | legisters                                        | 144 |
| 5.4        | Operat  | tion                                             | 147 |
|            | 5.4.1   | DATA-CRC                                         | 147 |
| -          |         |                                                  |     |
| Cha        | oter 6  | Clock Generator                                  | 148 |
| 6.1        | Overvi  | ew                                               | 148 |
|            | 6.1.1   | Features                                         | 148 |
|            | 6.1.2   | Description                                      | 149 |
| 6.2        | Contro  | ol Registers                                     | 151 |
| 6.3        | Clock   | Monitor                                          | 152 |
|            | 6.3.1   | Clock Monitor registers                          | 152 |
|            | 6.3.2   | Operation of the Clock Monitor                   | 154 |
| 6.4        | Power   | Save Control.                                    | 156 |
|            | 6.4.1   | HALT mode                                        | 157 |
|            |         |                                                  |     |
| Cha        | oter 7  | Flash Memory                                     | 159 |
| 7.1        | Code F  | Flash Memory Overview                            | 160 |
|            | 7.1.1   | Code flash memory features                       | 160 |
|            | 7.1.2   | Code flash memory mapping                        | 160 |
|            | 7.1.3   | Code flash memory functional outline             | 162 |
|            | 7.1.4   | Code flash memory erasure and rewrite            | 164 |
|            | 7.1.5   | Code flash memory error detection                | 166 |
| 7.2        | Data F  | lash Memory                                      | 168 |
|            | 7.2.1   | Data flash memory features                       | 168 |
|            | 7.2.2   | Data flash memory map                            | 168 |
|            | 7.2.3   | Data flash control register                      | 169 |
|            | 7.2.4   | Data flash reading                               | 169 |
|            | 7.2.5   | Data flash writing                               | 169 |
| 7.3        | Flash F | Programming with Flash Programmer                | 170 |
|            | 7.3.1   | Programming environment                          | 170 |
|            | 7.3.2   | Communication mode                               | 171 |
|            | 7.3.3   | Pin connection with flash programmer PG-FP5      | 173 |
|            | 7.3.4   | Flash memory programming control                 | 175 |
| 7.4        | Code F  | Flash Self-Programming                           | 181 |
|            | 7.4.1   | Self-programming enable                          | 182 |
|            | 7.4.2   | Self-programming library functions               | 182 |
|            | 7.4.3   | Secure self-programming (boot cluster swapping)  | 183 |
|            | 7.4.4   | Interrupt handling during flash self-programming | 186 |
| Cha        | oter 8  | Data Protection and Security                     | 107 |
| •          |         | -                                                |     |
| 8.1<br>0.0 |         |                                                  |     |
| 8.2        |         | Debug Interface Protection                       |     |
| 8.3        | riash I | Programmer and Self-Programming Protection       | 188 |
| Cha        | oter 9  | Bus and Memory Control (BCU, MEMC)               | 192 |
| 9.1        |         |                                                  |     |
| 3.1        | Overvi  | G 4A · · · · · · · · · · · · · · · · · ·         | 192 |



|                                      | 9.1.1                                                                                                                                                              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 193                                                                                                                               |
|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
|                                      | 9.1.2                                                                                                                                                              | Memory areas/banks and chip select signals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 194                                                                                                                               |
|                                      | 9.1.3                                                                                                                                                              | Peripheral I/O areas                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 197                                                                                                                               |
|                                      | 9.1.4                                                                                                                                                              | Data flash access                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 199                                                                                                                               |
|                                      | 9.1.5                                                                                                                                                              | CRC module access                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 200                                                                                                                               |
|                                      | 9.1.6                                                                                                                                                              | Boundary operation conditions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 201                                                                                                                               |
|                                      | 9.1.7                                                                                                                                                              | Initializing access to the Data flash memory and the CRC module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 202                                                                                                                               |
| 9.2                                  | Registe                                                                                                                                                            | ers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 203                                                                                                                               |
|                                      | 9.2.1                                                                                                                                                              | BCU registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 204                                                                                                                               |
|                                      | 9.2.2                                                                                                                                                              | Memory Controller registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 206                                                                                                                               |
| Char                                 | ntor 10                                                                                                                                                            | DMA Functions (DMA Controller)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 011                                                                                                                               |
| -                                    |                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                   |
| 10.1                                 |                                                                                                                                                                    | ew                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                   |
|                                      | 10.1.1                                                                                                                                                             | Principle of operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                   |
|                                      | 10.1.2                                                                                                                                                             | Forcible termination of DMA transfer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                   |
| 10.0                                 | 10.1.3                                                                                                                                                             | DMA interrupt function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                   |
| 10.2                                 | •                                                                                                                                                                  | ers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                   |
| 10.3                                 |                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                   |
|                                      | 10.3.1                                                                                                                                                             | DMA transfer from A/D Converter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                   |
|                                      | 10.3.2                                                                                                                                                             | DMA transfer to Timer S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                   |
|                                      | 10.3.3                                                                                                                                                             | DMA transfer to/from serial interfaces.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                   |
|                                      | 10.3.4                                                                                                                                                             | Example of forcible termination of DMA transfer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 240                                                                                                                               |
| Chap                                 | oter 11                                                                                                                                                            | Asynchronous Serial Interface (UARTC)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 241                                                                                                                               |
| . 11.1                               |                                                                                                                                                                    | •<br>•                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                   |
| 11.2                                 |                                                                                                                                                                    | uration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                   |
| 11.3                                 | •                                                                                                                                                                  | Registers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                   |
| 11.4                                 |                                                                                                                                                                    | pt Request Signals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                   |
| 11.5                                 | -                                                                                                                                                                  | ion                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                   |
|                                      | •                                                                                                                                                                  | Data format                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                   |
|                                      | 11.5.1                                                                                                                                                             | Dala 101111al                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 256                                                                                                                               |
|                                      | 11.5.1<br>11.5.2                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                   |
|                                      | 11.5.2                                                                                                                                                             | SBF transmission/reception format                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 258                                                                                                                               |
|                                      | 11.5.2<br>11.5.3                                                                                                                                                   | SBF transmission/reception format                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 258<br>260                                                                                                                        |
|                                      | 11.5.2<br>11.5.3<br>11.5.4                                                                                                                                         | SBF transmission/reception format                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 258<br>260<br>260                                                                                                                 |
|                                      | 11.5.2<br>11.5.3                                                                                                                                                   | SBF transmission/reception format         SBF transmission         SBF reception         UART transmission                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 258<br>260<br>260<br>262                                                                                                          |
|                                      | 11.5.2<br>11.5.3<br>11.5.4<br>11.5.5                                                                                                                               | SBF transmission/reception format.         SBF transmission         SBF reception         UART transmission         Continuous transmission procedure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 258<br>260<br>260<br>262<br>263                                                                                                   |
|                                      | 11.5.2<br>11.5.3<br>11.5.4<br>11.5.5<br>11.5.6                                                                                                                     | SBF transmission/reception formatSBF transmissionSBF receptionUART transmissionContinuous transmission procedureUART reception                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 258<br>260<br>260<br>262<br>263<br>265                                                                                            |
|                                      | 11.5.2<br>11.5.3<br>11.5.4<br>11.5.5<br>11.5.6<br>11.5.7                                                                                                           | SBF transmission/reception formatSBF transmissionSBF receptionUART transmissionContinuous transmission procedureUART receptionReception errors                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 258<br>260<br>260<br>262<br>263<br>265<br>267                                                                                     |
|                                      | 11.5.2<br>11.5.3<br>11.5.4<br>11.5.5<br>11.5.6<br>11.5.7<br>11.5.8<br>11.5.9                                                                                       | SBF transmission/reception formatSBF transmissionSBF receptionUART transmissionContinuous transmission procedureUART reception                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 258<br>260<br>260<br>262<br>263<br>265<br>267<br>267                                                                              |
| 11.6                                 | 11.5.2<br>11.5.3<br>11.5.4<br>11.5.5<br>11.5.6<br>11.5.7<br>11.5.8<br>11.5.9<br>11.5.10                                                                            | SBF transmission/reception format.SBF transmissionSBF receptionUART transmissionContinuous transmission procedureUART receptionReception errorsParity types and operations.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 258<br>260<br>260<br>262<br>263<br>265<br>267<br>267<br>269                                                                       |
| 11.6<br>11.7                         | 11.5.2<br>11.5.3<br>11.5.4<br>11.5.5<br>11.5.6<br>11.5.7<br>11.5.8<br>11.5.9<br>11.5.10<br>Baud F                                                                  | SBF transmission/reception format.         SBF transmission         SBF reception         UART transmission         Continuous transmission procedure         UART reception         Reception errors         Parity types and operations.         Receive data noise filter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 258<br>260<br>260<br>262<br>263<br>265<br>267<br>269<br>269<br>270                                                                |
| -                                    | 11.5.2<br>11.5.3<br>11.5.4<br>11.5.5<br>11.5.6<br>11.5.7<br>11.5.8<br>11.5.9<br>11.5.10<br>Baud F                                                                  | SBF transmission/reception format.         SBF transmission         SBF reception         UART transmission         Continuous transmission procedure         UART reception.         Reception errors         Parity types and operations.         Receive data noise filter         Rate Generator.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 258<br>260<br>260<br>262<br>263<br>265<br>267<br>269<br>269<br>270                                                                |
| 11.7                                 | 11.5.2<br>11.5.3<br>11.5.4<br>11.5.5<br>11.5.6<br>11.5.7<br>11.5.8<br>11.5.9<br>11.5.10<br>Baud R<br>Caution                                                       | SBF transmission/reception format.<br>SBF transmission<br>SBF reception<br>UART transmission<br>Continuous transmission procedure<br>UART reception.<br>Reception errors<br>Parity types and operations.<br>Receive data noise filter<br>Receive data noise filter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 258<br>260<br>260<br>262<br>263<br>265<br>267<br>267<br>267<br>269<br>270<br>277                                                  |
| 11.7                                 | 11.5.2<br>11.5.3<br>11.5.4<br>11.5.5<br>11.5.6<br>11.5.7<br>11.5.8<br>11.5.9<br>11.5.10<br>Baud R<br>Caution                                                       | SBF transmission/reception format.<br>SBF transmission<br>SBF reception<br>UART transmission<br>Continuous transmission procedure<br>UART reception.<br>Reception errors<br>Parity types and operations.<br>Receive data noise filter<br>Rate Generator.<br>Material Interface (CSIB)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 258<br>260<br>260<br>262<br>263<br>265<br>267<br>269<br>269<br>270<br>277<br>278<br>278                                           |
| 11.7<br>Chap                         | 11.5.2<br>11.5.3<br>11.5.4<br>11.5.5<br>11.5.6<br>11.5.7<br>11.5.8<br>11.5.9<br>11.5.10<br>Baud R<br>Caution                                                       | SBF transmission/reception format.<br>SBF transmission<br>SBF reception<br>UART transmission<br>Continuous transmission procedure<br>UART reception.<br>Reception errors<br>Parity types and operations.<br>Receive data noise filter<br>Receive data noise filter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 258<br>260<br>260<br>262<br>263<br>265<br>267<br>269<br>269<br>270<br>277<br>278<br>278                                           |
| 11.7<br>Char<br>12.1                 | 11.5.2<br>11.5.3<br>11.5.4<br>11.5.5<br>11.5.6<br>11.5.7<br>11.5.8<br>11.5.9<br>11.5.10<br>Baud R<br>Caution<br>Dter 12<br>Feature<br>Configu                      | SBF transmission/reception format.<br>SBF transmission<br>SBF reception<br>UART transmission<br>Continuous transmission procedure<br>UART reception.<br>Reception errors<br>Parity types and operations.<br>Receive data noise filter<br>Rate Generator.<br>Material Interface (CSIB)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 258<br>260<br>262<br>262<br>263<br>265<br>267<br>267<br>269<br>270<br>270<br>278<br>278<br>278<br>279                             |
| 11.7<br>Char<br>12.1<br>12.2         | 11.5.2<br>11.5.3<br>11.5.4<br>11.5.5<br>11.5.6<br>11.5.7<br>11.5.8<br>11.5.9<br>11.5.10<br>Baud R<br>Caution<br>Dter 12<br>Feature<br>Configu                      | SBF transmission/reception format.<br>SBF transmission<br>SBF reception .<br>UART transmission .<br>Continuous transmission procedure<br>UART reception.<br>Reception errors .<br>Parity types and operations.<br>Receive data noise filter .<br>Rate Generator.<br>Ins.<br>Clocked Serial Interface (CSIB)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 258<br>260<br>260<br>262<br>263<br>265<br>267<br>267<br>269<br>270<br>277<br>278<br>278<br>278<br>279<br>281                      |
| 11.7<br>Char<br>12.1<br>12.2<br>12.3 | 11.5.2<br>11.5.3<br>11.5.4<br>11.5.5<br>11.5.6<br>11.5.7<br>11.5.8<br>11.5.9<br>11.5.10<br>Baud R<br>Caution<br>Dter 12<br>Feature<br>Configu                      | SBF transmission/reception format.<br>SBF transmission<br>SBF reception<br>UART transmission<br>Continuous transmission procedure<br>UART reception.<br>Reception errors<br>Parity types and operations.<br>Receive data noise filter<br>Receive data noise fil                                                                                                                     | 258<br>260<br>262<br>263<br>265<br>265<br>267<br>269<br>269<br>270<br>277<br>278<br>278<br>278<br>279<br>281<br>288               |
| 11.7<br>Char<br>12.1<br>12.2<br>12.3 | 11.5.2<br>11.5.3<br>11.5.4<br>11.5.5<br>11.5.6<br>11.5.7<br>11.5.8<br>11.5.9<br>11.5.10<br>Baud R<br>Caution<br>Dter 12<br>Feature<br>Configu<br>CSIB C<br>Operati | SBF transmission/reception format.<br>SBF transmission .<br>SBF reception .<br>UART transmission .<br>Continuous transmission procedure .<br>UART reception .<br>Reception errors .<br>Parity types and operations.<br>Receive data noise filter .<br>Receive data noise filter .<br>Receive data noise filter .<br>Receive data noise filter .<br>Receive data noise filter .<br>Securation .<br>Securati | 258<br>260<br>262<br>263<br>265<br>267<br>267<br>267<br>267<br>269<br>270<br>270<br>278<br>278<br>278<br>278<br>278<br>288<br>288 |



|      | 12.4.3  | Continuous mode (master mode, transmission/reception mode) 291 |
|------|---------|----------------------------------------------------------------|
|      | 12.4.4  | Continuous mode (master mode, reception mode)                  |
|      | 12.4.5  | Continuous reception mode (error)                              |
|      | 12.4.6  | Continuous mode (slave mode, transmission/reception mode) 295  |
|      | 12.4.7  | Continuous mode (slave mode, reception mode) 297               |
|      | 12.4.8  | Clock timing                                                   |
| 12.5 | Output  | Pins                                                           |
| 12.6 | Operati | ion Flow                                                       |
| 12.7 | Baud R  | ate Generator                                                  |
|      | 12.7.1  | Overview                                                       |
|      | 12.7.2  | Baud rate generator registers 308                              |
|      | 12.7.3  | Baud rate generation                                           |
| 12.8 | Caution | ns                                                             |
|      | 12.8.1  | CSIB operation stop                                            |

# Chapter 13 Enhanced Queued Clocked Serial Interface (CSIE)...

040

|      |         | 312                      |     |
|------|---------|--------------------------|-----|
| 13.1 | Feature | es                       | 312 |
|      | 13.1.1  | Queued CSI block diagram | 313 |

|      | 13.1.1  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 13.1.2  | Input/Output pins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 13.2 | Queued  | I CSI Control Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 13.3 | Explana | ation of Queued CSI Functions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      | 13.3.1  | Transmit buffer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|      | 13.3.2  | Serial data direction select function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|      | 13.3.3  | Data length select function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|      | 13.3.4  | Slave mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|      | 13.3.5  | Master mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|      | 13.3.6  | Transmission clock select function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|      | 13.3.7  | Description of the single transfer mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|      | 13.3.8  | Description of the block transfer mode 341                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|      | 13.3.9  | Description of the operation modes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|      | 13.3.10 | Additional timing and delay selections 343                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|      | 13.3.11 | Default pin levels                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|      | 13.3.12 | Transmit buffer overflow interrupt signal (INTCEnOF)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|      | 13.3.13 | Enhanced chip select timing 348                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 13.4 | Operati | <b>ng Procedure</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|      | 13.4.1  | Single transfer mode (master mode, transmit only mode) 355                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|      | 13.4.2  | Single transfer mode (master mode, receive only mode) 356                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|      | 13.4.3  | Single transfer mode (master mode, transmit/receive mode) 357                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      | 13.4.4  | Single transfer mode (slave mode, transmit only mode) 358                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|      | 13.4.5  | Single transfer mode (slave mode, receive only mode) 359                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|      | 13.4.6  | Single transfer mode (slave mode, transmit/receive mode) 360                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|      | 13.4.7  | Block transfer mode (master mode, transmit only mode)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|      | 13.4.8  | Block transfer mode (master mode, receive only mode)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|      | 13.4.9  | Block transfer mode (master mode, transmit/receive mode) 363                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|      | 13.4.10 | Block transfer mode (slave mode, transmit only mode)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|      | 13.4.11 | ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, ,, , |
|      | 13.4.12 | Block transfer mode (slave mode, transmit/receive mode)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 13.5 | Caution | <b>IS</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |



|       | 13.5.1   | Inconsistent read data in master mode                 | . 367 |
|-------|----------|-------------------------------------------------------|-------|
|       | 13.5.2   | Transmit/receive enable after CEnTX0 write            | . 367 |
|       |          |                                                       |       |
| Chap  | ter 14   | CAN Controller (CAN)                                  | . 368 |
| 14.1  | Feature  | 9 <b>5</b>                                            | . 368 |
|       | 14.1.1   | Overview of functions                                 |       |
|       | 14.1.2   | Configuration                                         | . 370 |
| 14.2  | CAN Pr   | otocol                                                |       |
|       | 14.2.1   | Frame format.                                         | . 371 |
|       | 14.2.2   | Frame types                                           | . 372 |
|       | 14.2.3   | Data frame and remote frame                           | . 372 |
|       | 14.2.4   | Error frame                                           | . 379 |
|       | 14.2.5   | Overload frame                                        | . 380 |
| 14.3  | Functio  | ns                                                    | . 381 |
|       | 14.3.1   | Determining bus priority                              | . 381 |
|       | 14.3.2   | Bit stuffing                                          | . 381 |
|       | 14.3.3   | Multi masters                                         | . 382 |
|       | 14.3.4   | Multi cast                                            | . 382 |
|       | 14.3.5   | CAN sleep mode/CAN stop mode function                 | . 382 |
|       | 14.3.6   | Error control function                                | . 382 |
|       | 14.3.7   | Baud rate control function                            | . 389 |
| 14.4  | Connec   | tion with Target System                               | . 392 |
| 14.5  | Internal | Registers of CAN Controller                           | . 393 |
|       | 14.5.1   | CAN module register and message buffer addresses      | . 393 |
|       | 14.5.2   | CAN Controller configuration                          | . 394 |
|       | 14.5.3   | CAN registers overview                                | . 395 |
|       | 14.5.4   | Register bit configuration                            | . 397 |
| 14.6  | Bit Set/ | Clear Function                                        | . 400 |
| 14.7  | Control  | Registers                                             | . 402 |
| 14.8  | CAN Co   | ontroller Initialization                              | . 438 |
|       | 14.8.1   | Initialization of CAN module                          | . 438 |
|       | 14.8.2   | Initialization of message buffer                      | . 438 |
|       | 14.8.3   | Redefinition of message buffer                        | . 438 |
|       | 14.8.4   | Transition from initialization mode to operation mode | . 440 |
|       | 14.8.5   | Resetting error counter CnERC of CAN module           | . 441 |
| 14.9  | Messag   | e Reception                                           |       |
|       | 14.9.1   | Message reception                                     | . 442 |
|       | 14.9.2   | Receive data read                                     |       |
|       | 14.9.3   | Receive history list function.                        |       |
|       | 14.9.4   | Mask function                                         |       |
|       | 14.9.5   | Multi buffer receive block function                   |       |
|       | 14.9.6   | Remote frame reception                                |       |
| 14.10 | -        | Je Transmission                                       |       |
|       |          | Message transmission                                  |       |
|       |          | Transmit history list function                        |       |
|       |          | Automatic block transmission (ABT)                    |       |
|       |          | Transmission abort process                            |       |
|       |          | Remote frame transmission                             |       |
| 14.11 |          | Saving Modes.                                         |       |
|       | 14.11.1  | CAN sleep mode                                        | . 458 |



|              | 14.11.2 | CAN stop mode                                                  | 461  |
|--------------|---------|----------------------------------------------------------------|------|
|              | 14.11.3 | Example of using power saving modes                            | 462  |
| 14.12        | Interru | pt Function                                                    | 463  |
| 14.13        | Diagno  | sis Functions and Special Operational Modes                    | 464  |
|              | 14.13.1 | Receive-only mode                                              | 464  |
|              | 14.13.2 | Single-shot mode                                               | 465  |
|              | 14.13.3 | Self-test mode                                                 | 466  |
|              | 14.13.4 | Receive/transmit operation in each operation mode              | 467  |
| 14.14        | Time S  | tamp Function                                                  | 468  |
|              | 14.14.1 | Time stamp function                                            | 468  |
| 14.15        |         | ate Settings                                                   |      |
|              |         | Baud rate setting conditions                                   |      |
|              |         | Representative examples of baud rate settings                  |      |
| 14.16        | Operat  | ion of CAN Controller                                          | 477  |
| <b>.</b>     |         |                                                                |      |
| Chap         | ter 15  | A/D Converter (ADC)                                            | 506  |
| 15.1         | Feature | es                                                             | 506  |
| 15.2         | Config  | uration                                                        | 507  |
| 15.3         |         | I Registers                                                    |      |
| 15.4         | Operat  | ion                                                            |      |
|              | 15.4.1  | Basic operation                                                | 519  |
|              | 15.4.2  | Operation mode and trigger mode                                |      |
| 15.5         | Operat  | ion in A/D Trigger Mode                                        |      |
|              | 15.5.1  | Select mode operation                                          |      |
|              | 15.5.2  | Scan mode operation                                            |      |
| 15.6         | •       | ion in Timer Trigger Mode                                      |      |
|              | 15.6.1  | Select mode operation                                          |      |
|              | 15.6.2  | Scan mode operation                                            |      |
| 15.7         | -       | ion in External Trigger Mode                                   |      |
|              | 15.7.1  | Select mode operation                                          |      |
|              | 15.7.2  | Scan mode operation                                            |      |
| 15.8         | Precau  | tions                                                          | 538  |
| Chan         | tor 16  | 16 Bit Timer/Event Counter AA (TAA)                            | - 44 |
| •            |         | 16-Bit Timer/Event Counter AA (TAA)                            |      |
| 16.1         |         |                                                                |      |
| 16.2         |         | on Outline                                                     |      |
| 16.3<br>16.4 | -       | uration                                                        |      |
| 16.4<br>16.5 | -       | election Registers                                             |      |
| 16.5<br>16.6 |         | ion                                                            |      |
| 10.0         | 16.6.1  | Anytime write and reload.                                      |      |
|              | 16.6.2  | Interval timer mode (TAAnMD2 to TAAnMD0 = $000_B$ )            |      |
|              |         |                                                                |      |
|              | 16.6.3  | External event counter mode (TAAnMD2 to TAAnMD0 = $001_B$ )    |      |
|              | 16.6.4  | External trigger pulse mode (TAAnMD2 to TAAnMD0 = $010_B$ )    |      |
|              | 16.6.5  | One-shot pulse mode (TAAnMD2 to TAAnMD0 = $011_B$ )            |      |
|              | 16.6.6  | PWM mode (TAAnMD2 to TAAnMD0 = 100 <sub>B</sub> )              | 582  |
|              | 16.6.7  | Free-running mode (TAAnMD2 to TAAnMD0 = 101 <sub>B</sub> )     | 587  |
|              | 16.6.8  | Pulse width measurement mode<br>(TAAnMD2 to TAAnMD0 = 110B)593 |      |

RENESAS

|       | 16.6.9  | 32-bit Capture in free-running cascade mode                                                      | 600  |
|-------|---------|--------------------------------------------------------------------------------------------------|------|
|       | 16.6.10 | Specific TAAnCCRm overflow value write                                                           | 605  |
| 16.7  | Timer S | Synchronization Operation Function                                                               | 611  |
|       |         |                                                                                                  |      |
| Chap  | ter 17  | 16-Bit Timer/Event Counter S (TMS)                                                               | 613  |
| 17.1  |         | S                                                                                                |      |
| 17.2  |         | uration                                                                                          |      |
| 17.3  | -       | Register                                                                                         |      |
| 17.4  |         |                                                                                                  |      |
|       | 17.4.1  | 16-bit counter basic operation.                                                                  |      |
|       | 17.4.2  | Compare register rewriting                                                                       |      |
|       | 17.4.3  | Output list in each mode                                                                         |      |
| 17.5  | Match I | nterrupt                                                                                         |      |
|       | 17.5.1  | Caution on compare match interrupt                                                               |      |
| 17.6  | Flags   | · · · · · · · · · · · · · · · · · · ·                                                            |      |
|       | 17.6.1  | Count-up flags (TSnCUF, TSnSUF)                                                                  |      |
|       | 17.6.2  | Positive/negative-phase simultaneous active detection flag (TSnTBF)                              |      |
|       | 17.6.3  | Reload request flag (TSnRSF)                                                                     |      |
|       | 17.6.4  | Noise detection flag (TSnNDF)                                                                    |      |
|       | 17.6.5  | Pattern order detection flag (TSnTSF)                                                            |      |
|       | 17.6.6  | Pattern error detection flag (TSnPEF).                                                           |      |
|       | 17.6.7  | Pattern reverse detection flag (TSnPRF)                                                          |      |
|       | 17.6.8  | TAPTSn2 to TAPTSn0 pin abnormal toggle detection flag (TSnPTF)                                   |      |
|       | 17.6.9  | TSnSTCI0, TSnSTCI1 signal simultaneous trigger detection flag (TSnTI<br>730                      | ϽF)  |
|       | 17610   | Pattern phase difference detection flag (TSnPPF)                                                 | 731  |
|       |         | Overflow flag (TSnOVF)                                                                           |      |
|       |         | Timer output pattern flags (TSnOPF2 to TSnOPF0)                                                  |      |
|       |         | Pattern switch detection flag (TSnESG)                                                           |      |
| 17.7  |         | ot Thinning out Function.                                                                        |      |
|       | 17.7.1  | Interrupt thinning out function operation                                                        |      |
|       | 17.7.2  | Operation example when peak and trough interrupts occur alternatively (i accuracy T-PWM mode)738 |      |
|       | 17.7.3  | Operation example when only peak interrupt occurs (in high-accuracy T<br>mode)740                | -PWM |
|       | 17.7.4  | Operation example when only trough interrupt occurs (in high-accuracy T                          | -PWM |
|       | 17.7.5  | mode)742<br>Operation example when only peak interrupt occurs (in PWM mode)                      | 744  |
| 170   |         |                                                                                                  |      |
| 17.8  |         |                                                                                                  |      |
| 17.9  | 17.8.1  | A/D conversion trigger operation                                                                 |      |
| 17.9  | 17.9.1  |                                                                                                  |      |
|       | 17.9.1  | Error interrupt function                                                                         |      |
| 17.10 |         | Warning interrupt function                                                                       |      |
| 17.10 | -       | on in Each Mode                                                                                  |      |
|       |         | Interval timer mode                                                                              |      |
|       |         | External event count mode                                                                        |      |
|       |         | External trigger pulse output mode                                                               |      |
|       |         | One-shot pulse mode PWM mode                                                                     |      |
|       |         | Free-running mode                                                                                |      |
|       | 17.10.0 |                                                                                                  |      |



|      | 17.10.7 | ' Triangular-wave PWM mode                | . 790 |
|------|---------|-------------------------------------------|-------|
|      | 17.10.8 | B High-accuracy T-PWM mode                | . 795 |
|      |         | PWM mode with dead time                   |       |
|      |         | 0120° excitation mode                     |       |
|      |         | 1 Special 120° excitation mode            |       |
|      |         | 2Special pattern output mode              |       |
|      |         | 3Software output function                 |       |
|      | 17.10.1 | 4180° excitation control function         | . 938 |
| Cha  | atar 10 | 16 bit Timer/Event Counter T (TMT)        |       |
| -    |         | 6 16-bit Timer/Event Counter T (TMT)      |       |
| 18.1 |         | es                                        |       |
| 18.2 |         | on Outline                                |       |
| 18.3 | •       |                                           |       |
| 18.4 |         | I Registers                               |       |
| 18.5 |         | Operation                                 |       |
|      | 18.5.1  | Basic counter operation                   |       |
|      | 18.5.2  | Method for writing to compare register    |       |
| 18.6 | •       | ion in Each Mode                          |       |
|      | 18.6.1  | Interval timer mode                       |       |
|      | 18.6.2  | External event count mode                 |       |
|      | 18.6.3  | External trigger pulse output mode        |       |
|      | 18.6.4  | One-shot pulse mode                       |       |
|      | 18.6.5  | PWM mode                                  |       |
|      | 18.6.6  | Free-running mode                         |       |
|      | 18.6.7  | Pulse width measurement mode              |       |
|      | 18.6.8  | Triangular wave PWM mode                  |       |
|      | 18.6.9  | Encoder count function                    |       |
|      |         | Offset trigger generation mode            |       |
| 18.7 | Cautio  | ns                                        |       |
|      | 18.7.1  | TMT 'Encoder load enable'-mode limitation | 1019  |
| Cha  | ator 10 | Timer Interconnection                     | 1000  |
| -    |         |                                           |       |
| 19.1 |         | I register                                |       |
| 19.2 |         |                                           |       |
|      | 19.2.1  |                                           |       |
| 10.0 | 19.2.2  | Configuration                             |       |
| 19.3 |         | e Pulse Input Control Function            |       |
|      | 19.3.1  |                                           |       |
| 10.4 | 19.3.2  |                                           |       |
| 19.4 |         |                                           |       |
|      | 19.4.1  |                                           |       |
|      | 19.4.2  | Configuration                             |       |
| 19.5 | TMT as  | s Filter for TMAA                         | 1033  |
| Cha  | oter 20 | On-Chip Debug Unit                        | 1034  |
| 20.1 | Functio | onal Outline                              | 1034  |
|      | 20.1.1  | Debug functions                           |       |
|      | 20.1.2  | Security function                         |       |
| 20.2 | Conne   | ction to N-Wire Emulator                  |       |
|      |         |                                           |       |



| 20.3  |         | KEL connectortions and Cautions on On-Chip Debug Function |      |
|-------|---------|-----------------------------------------------------------|------|
| Chap  | ter 21  | Auxiliary Frequency Output Function (AFO)                 | 1042 |
| 21.1  | Feature | S                                                         | 1042 |
| 21.2  | Configu | uration                                                   | 1042 |
| 21.3  | Control | Registers                                                 | 1043 |
| 21.4  | Operati | on                                                        | 1045 |
|       | 21.4.1  | Auxiliary frequency generation                            | 1045 |
|       | 21.4.2  | Interval timer function                                   | 1045 |
| Chap  | ter 22  | Reset Function                                            | 1046 |
| 22.1  | Feature | 9 <b>S</b>                                                | 1046 |
| 22.2  | Configu | uration                                                   | 1046 |
| 22.3  | Operati | on                                                        | 1048 |
| Арре  | ndix A  | Special Function Registers                                | 1049 |
| A.1   | CAN Re  | egisters                                                  | 1049 |
| A.2   | Other S | pecial Function Registers                                 | 1052 |
| Revis | ion Hi  | story                                                     | 1067 |
| Index |         |                                                           | 1069 |



# **Chapter 1 Introduction**

The V850E/PHC3 is a product in NEC Electronics' V850 family of single-chip microcontrollers designed for automotive applications.

# 1.1 General

With its high performance V850E CPU core and its compact feature set the V850E/PHC3 is especially suited for embedded control applications.

The V850E/PHC3 devices provide an excellent combination of general purpose peripheral functions like serial communication interfaces, timers/counters, measurement and control functions, with dedicated motor control timers and full CAN network support.

Thus equipped, the V850E/PHC3 product is ideally suited for automotive control applications, such as electric power steering (EPS). It is also an excellent choice for other embedded applications where a combination of sophisticated peripheral functions and CAN network support is required.

## (1) V850E CPU

The V850E CPU core is a 32-bit RISC processor. Through the use of basic instructions that can be executed in one clock period combined with an optimized pipeline architecture, it achieves marked improvements in instruction execution speed.

In addition, to make it ideal for use in digital control applications, a 32-bit hardware multiplier supports multiply instructions, saturated multiply instructions, bit operation instructions, etc.

Through two-byte basic instructions and instructions compatible with high level languages, the object code efficiency in a C compiler is increased, and program size can be reduced.

Further, because the on-chip interrupt controller provides high-speed interrupt response and processing, the device is well suited for high level real-time control applications.

#### (2) On-chip flash memory

The V850E/PHC3 microcontroller has on-chip flash memory. It is possible to program the controller directly in the target environment where it is mounted.

With this feature, system development time can be reduced and system maintainability after shipping can be markedly improved.



## (3) Reliability

Focus of the design was to achieve utmost reliability and availability. Flash memory and RAM are equipped with error correction code (ECC). ECC makes it possible to correct single bit errors automatically and to detect and flag double bit errors.

Writing to the flash is protected by various measures.

#### (4) A full range of software development tools

A development system is available that includes an optimized C compiler, debugger and other elements.

# 1.2 Features Summary

The CPU core provides:

- 96 instructions
- 32 general registers (32 bits each)
- Comprehensive instruction set:
  - V850E (compatible with V850, added powerful instructions for reducing code and increasing execution speed)
  - − Signed multiplication (16 bits × 16 bits → 32 bits or 32 bits × 32 bits → 64 bits) in 1 to 2 clocks
  - Saturated operation instructions (with overflow/underflow detection)
  - 32-bit shift instructions in 1 clock cycle
  - Bit manipulation instructions
  - Load/store instructions with long/short format
  - Signed load instructions
- Linear address space 256 MB
- Floating Point Unit: IEEE754 Single-precision



The following table gives an overview of the most outstanding controller features.

## Table 1-1 V850E/PHC3 features

| Features          |                       | V850E/PHC3                                                                                               |
|-------------------|-----------------------|----------------------------------------------------------------------------------------------------------|
| CF                | PU                    | V850E (32-bit RISC) with single-precision FPU                                                            |
|                   | Code ROM              | 480KB                                                                                                    |
| Internal          | Mask ROM              | -                                                                                                        |
| memory            | RAM                   | 32 KB                                                                                                    |
|                   | Data Flash            | 32 KB                                                                                                    |
|                   | CPU<br>frequency      | 80 MHz                                                                                                   |
| Operating         | MainOSC               | operates on 16 MHz crystal                                                                               |
| clocks            | PLL ratio             | ×2, ×5                                                                                                   |
|                   | Internal oscillator   | 6.8 MHz typ.                                                                                             |
|                   | Non-maskable          | 1 ch                                                                                                     |
| Interrupts        | Maskable int.         | 98 ch                                                                                                    |
|                   | Maskable ext.         | 13 ch                                                                                                    |
| I/O lines         | I/O ports             | 76                                                                                                       |
|                   | Input ports           | 5                                                                                                        |
|                   | TAA                   | 10 ch (16-bit general purpose timer/counter, cascadable for 32-bit operations)                           |
| Timers            | TMS                   | 2 ch (16-bit timer/counter with Motor Control Functions)                                                 |
|                   | TMT                   | 2 ch (16-bit general purpose timer/counter with PWM functions)                                           |
|                   | Analog inputs         | 20                                                                                                       |
| A/D<br>converters | Resolution            | 10 bit                                                                                                   |
|                   | Туре                  | Successive approximation                                                                                 |
|                   | UARTC                 | 2 ch                                                                                                     |
| Serial            | CSIB                  | 2 ch Clocked Serial Interface                                                                            |
| interfaces        | CSIE                  | 2 ch queued CSI                                                                                          |
|                   | CAN                   | 2 ch CAN<br>(32 message buffers for each channel)                                                        |
| DN                | ЛА                    | 8 ch                                                                                                     |
|                   | Power save modes      | HALT                                                                                                     |
| Other             | Clock Monitor         | Main oscillator monitor                                                                                  |
| functions         | Aux. frequency output | Programmable baud rate generator                                                                         |
|                   | On-chip debug         | Connection of an external N-Wire emulator                                                                |
|                   | supply                | <ul> <li>3.3 V ± 0.3 V</li> <li>1.5V ± 0.15 V<br/>(refer to Data Sheet)</li> <li>144 pin LQFP</li> </ul> |
| Package           |                       |                                                                                                          |



# 1.3 Description

The following figure provides a functional block diagram of the V850E/PHC3 microcontroller.



Figure 1-1 V850E/PHC3 block diagram



# 1.3.1 Internal units

| CPU                | The CPU can execute almost all instruction processing, such as address calculation, arithmetic and logic operations, and data transfer, in one clock cycle under control of a five-stage pipeline. Dedicated hardware units such as a multiplier and a 32-bit barrel shifter are provided to speed up program execution. The integrated Single-precision Floating Point Unit simplifies the execution of complex control algorithms. |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Code<br>flash      | This is a built-in flash memory of 480 KB mapped to addresses 000 $0000_{\rm H}$ to 007 7FFF <sub>H</sub> . The CPU can access this memory in one clock when it fetches an instruction.                                                                                                                                                                                                                                              |
| Data flash         | A 32 KB data flash is provided, accessible via the Memory Controller.                                                                                                                                                                                                                                                                                                                                                                |
| RAM                | This is a RAM of 32KB mapped to addresses 3FF 7000 <sub>H</sub> to 3FF EFFF <sub>H</sub> . The CPU can access this RAM in one clock when it accesses data.                                                                                                                                                                                                                                                                           |
| DMA Controller     | The V850E/PHC3 has an eigth-channel DMA Controller that transfers data between the internal RAM and serial interfaces, Timer S and the A/D converter.                                                                                                                                                                                                                                                                                |
| BCU / MEMC         | The Bus Control Unit (BCU) controls peripheral bus access. The Memory Controller (MEMC) controls the access to the on-chip Data-CRC unit and the data flash memory.                                                                                                                                                                                                                                                                  |
| Clock Generator    | The Clock Generator generates the system clocks. It includes the crystal-<br>controlled 16 MHz main oscillator and an internal 6.8 MHz internal oscillator.                                                                                                                                                                                                                                                                          |
| Clock Monitor      | The Clock Monitor monitors the main oscillator. In case of failure, it can switch the CPU system and the Memory Controller to the internal oscillator.                                                                                                                                                                                                                                                                               |
| On-chip Debug Unit | An on-chip debug function that uses an N-Wire interface is provided.                                                                                                                                                                                                                                                                                                                                                                 |
| INTC               | The Interrupt Controller (INTC) processes non-maskable and maskable<br>interrupt requests from the on-chip peripheral hardware and external sources.<br>Eight levels of priorities can be specified for these interrupt requests, and<br>multiple servicing control can be performed on interrupt sources.                                                                                                                           |
| DATA-CRC           | The DATA-CRC (DATA Cyclic Redundency Check) can be used verify or generate CRC protected data streams of arbitrary length and different bit widths.                                                                                                                                                                                                                                                                                  |
| UARTC              | The UARTs provide 2-wire asynchronous serial interfaces.                                                                                                                                                                                                                                                                                                                                                                             |
| CSIB               | The Clocked Serial Interfaces are 3-wire variable-length serial interfaces.                                                                                                                                                                                                                                                                                                                                                          |
| CSIE               | The Enhanced Queued Clocked Serial Interfaces CSIE provide an internal FIFO buffer for queued operation.                                                                                                                                                                                                                                                                                                                             |
| CAN                | The CAN Controller of this device fulfills the requirements according ISO 11898. Additionally, the CAN Controller was tested according to the test procedures required by ISO 16845. The CAN Controller has successfully passed all test patterns. Beyond these test patterns, other tests like robustness tests and processor interface tests as recommended by C&S/FH Wolfenbuettel have been performed with success.              |
| A/D Converter      | These are two high-speed, high-resolution 10-bit A/D Converters, each with 10 analog input pins. They are of successive approximation type.                                                                                                                                                                                                                                                                                          |
| Timers/counters    | Ten 16-bit timers/event counters TAA, two 16-bit timers/event counters TMS with motor control capability, and two general purpose 16-bit timers TMT are provided.                                                                                                                                                                                                                                                                    |
| AFO                | The Auxiliary Frequency Output (AFO) provides a clock signal generated by a separate baud rate generator (BRG2).                                                                                                                                                                                                                                                                                                                     |

RENESAS

# 1.3.2 Structure of the manual

This manual explains how to use the V850E/PHC3 microcontroller devices. It provides comprehensive information about the building blocks, their features, and how to set registers in order to enable or disable specific functions.

The manual provides individual chapters for the building blocks. These chapters are organized according to the grouping in the diagram.

Core functions

"Pin Functions" on page 23 "CPU System Functions" on page 71 "Interrupt Controller (INTC)" on page 99 "CRC Function (CRC)" on page 142 "Clock Generator" on page 148

Memory access

*"Flash Memory" on page 159 "Bus and Memory Control (BCU, MEMC)" on page 192 "DMA Functions (DMA Controller)" on page 211* 

Communication interfaces

"Introduction" on page 17 "Clocked Serial Interface (CSIB)" on page 278 "Enhanced Queued Clocked Serial Interface (CSIE)" on page 312 "CAN Controller (CAN)" on page 368

• Measurement interfaces

"A/D Converter (ADC)" on page 506

• Timers

"16-Bit Timer/Event Counter AA (TAA)" on page 541 "16-Bit Timer/Event Counter S (TMS)" on page 613 "16-bit Timer/Event Counter T (TMT)" on page 940 "Timer Interconnection" on page 1020

Auxiliary functions

"On-Chip Debug Unit" on page 1034 "Auxiliary Frequency Output Function (AFO)" on page 1042

Power and reset

"Reset Function" on page 1046



# **Chapter 2** Pin Functions

This chapter lists the ports of the microcontroller. It presents the configuration of the ports for control functions. Noise elimination on input signals is explained and a recommendation for the connection of unused pins is given at the end of the chapter.

# 2.1 Overview

Features summary

The microcontroller offers various pins for input/output functions, so-called ports. The ports are organized in port groups.

To allocate other than general purpose input/output functions to the pins, several control registers are provided.

For a description of the terms pin, port or port group, see "Terms" on page 26.

• Number of ports and port groups:

- Input/Output ports:76
- Input ports: 5
- Port groups: 12
- 3.3 V I/O: Refer to the Data Sheet.
- Configuration possible for individual pins.
- Emergency shut-off configuration (only for dedicated ports 5 and 6)



# 2.1.1 Description



This microcontroller has the port groups shown below.

Figure 2-1 Port groups



Port group overview

*Table 2-1* gives an overview of the port groups. For each port group it shows the supported functions in port mode and in alternative mode. Any port group can operate in 8-bit or 1-bit units.

| Port          | Function           |                                                                                                                                                                                                      |  |  |  |  |
|---------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| group<br>name | Port mode          | Alternative mode                                                                                                                                                                                     |  |  |  |  |
| 0             | 5-bit input        | <ul> <li>External interrupt 0 to 3</li> <li>Non maskable interrupt</li> <li>Emergency shut-off control of Timers TMS0/TMS1</li> <li>ADC trigger input</li> </ul>                                     |  |  |  |  |
| 1             | 8-bit input/output | Timer TAA0 to TAA3 channels                                                                                                                                                                          |  |  |  |  |
| 2             | 8-bit input/output | Timer TAA4 to TAA7 channels                                                                                                                                                                          |  |  |  |  |
| 3             | 8-bit input/output | <ul> <li>External interrupt 4 and 5</li> <li>UARTC0 receive/transmit data,</li> <li>UARTC1 receive/transmit data</li> <li>CAN0 receive/transmit data,</li> <li>CAN1 receive/transmit data</li> </ul> |  |  |  |  |
| 4             | 6-bit input/output | <ul><li>CSIB0 data/clock line</li><li>CSIB1 data/clock line</li></ul>                                                                                                                                |  |  |  |  |
| 5             | 8-bit input/output | Timer TMS0 pulse signal output                                                                                                                                                                       |  |  |  |  |
| 6             | 8-bit input/output | Timer TMS1 pulse signal output                                                                                                                                                                       |  |  |  |  |
| 7             | 6-bit input/output | <ul> <li>Timer TMT0 channels</li> <li>Timer TMT1 channels</li> <li>External interrupt 12</li> <li>Auxiliary frequency output</li> </ul>                                                              |  |  |  |  |
| 8             | 7-bit input/output | <ul> <li>CSIE0 data/clock line</li> <li>CSIE0 chip select areas 0 to 3</li> <li>CSIB0 serial slave select input</li> <li>External interrupts 6 to 8</li> </ul>                                       |  |  |  |  |
| 9             | 7-bit input/output | <ul> <li>CSIE0 chip select areas 4 to 7</li> <li>CSIE1 data/clock line</li> <li>CSIE1 chip select areas</li> <li>CSIB1 serial slave select input</li> <li>External interrupts 9 to 11</li> </ul>     |  |  |  |  |
| 10            | 4-bit input/output | <ul><li>Timer TAA8 channels</li><li>Timer TAA9 channels</li></ul>                                                                                                                                    |  |  |  |  |
| 11            | 6-bit input/output | <ul><li>Timer TMS0 input channels</li><li>Timer TMS1 input channels</li></ul>                                                                                                                        |  |  |  |  |

Pin configuration To define the function of a pin, several control registers are provided.

- For a general description of the registers, see *"Port Group Configuration Registers" on page 27*.
- For every port, detailed information on the configuration registers is given in *"Port Group Configuration" on page 40.*

There are several types of control circuits, defined as port types. For a description of the port types, see *"Port Types Diagrams" on page 44*.

RENESAS

# 2.1.2 Terms

In this section, the following terms are used:

• Pin

Denotes the physical pin. Every pin is uniquely denoted by its pin number. A pin can be used in several modes. Depending on the selected mode, a pin name is allocated to the pin.

• Port group

Denotes a group of pins. The pins of a port group have a common set of port mode control registers.

• Port mode / Port

A pin in port mode works as a general purpose input/output pin. It is then called "port".

The corresponding name is Pnm. For example, P07 denotes port 7 of port group 0. It is referenced as "port P07".

Alternative mode

In alternative mode, a pin can work in various non-general purpose input/output functions, for example, as the input/output pin of on-chip peripherals.

The corresponding pin name depends on the selected function. For example, pin INTP0 denotes the pin for one of the external interrupt inputs. Note that for example P01 and INTP0 denote the same physical pin. The different names indicate the function in which the pin is being operated.

• Port type

A control circuit evaluates the settings of the configuration registers. There are different types of control circuits, called "port types".

# 2.1.3 Noise elimination

The input signals at some pins are passing a filter to remove noise and glitches. The microcontroller supports both analog and digital filters.

See "Noise Elimination" on page 63 for a detailed description.



# 2.2 Port Group Configuration Registers

This section starts with an overview of all configuration registers and then presents all registers in detail. The configuration registers are classified in the following groups:

- "Pin function configuration" on page 28
- "Pin data input/output" on page 32
- "Emergency shut-off configuration" on page 34
- "Write enable register" on page 38

# 2.2.1 Overview

For the configuration of the individual pins of the port groups, the following registers are used:

## Table 2-2 Registers for port group configuration

| Register name                            | Shortcut | Function                                  |
|------------------------------------------|----------|-------------------------------------------|
| Port mode control register               | PMCn     | Pin function configuration                |
| Port mode register                       | PMn      |                                           |
| Port function control register           | PFCn     |                                           |
| Port function control expansion register | PFCEn    |                                           |
| Port register                            | Pn       | Pin data input/output                     |
| Emergency shut-off control register      | PESCn    | Emergency shut-off                        |
| Emergency shut-off status register       | ESOSTn   | configuration                             |
| Emergency shut-off mask register         | PESMKn   |                                           |
| Write enable register                    | PRCMD    | Port configuration registers write enable |





# 2.2.2 Pin function configuration

The registers for pin function configuration define the general function of a pin:

- port mode or alternative mode
- in port mode: input mode or output mode
- in alternative mode: selection of one of the alternative functions in alternative mode

An overview of the register settings is given in the table below.

 Table 2-3
 Pin function configuration (overview)

| Function                                  |     | 1/0 |      |     |                  |
|-------------------------------------------|-----|-----|------|-----|------------------|
| Function                                  | PMC | РМ  | PFCE | PFC | 1/0              |
| Port mode (output)                        | 0   | 0   | Х    | Х   | 0                |
| Port mode (input)                         |     | 1   | Х    | Х   | I                |
| Alternative mode (alternative function 1) |     |     | 0    | 0   |                  |
| Alternative mode (alternative function 2) | 1   | x   | 0    | 1   | I/O <sup>a</sup> |
| Alternative mode (alternative function 3) |     | ^   | 1    | 0   | 1/0              |
| Alternative mode (alternative function 4) |     |     | I    | 1   |                  |

a) In alternative mode, the corresponding port type defines whether a pin is in input mode or output mode.



#### (1) PMCn - Port mode control register

The PMCn register specifies whether the individual pins of port group n are in port mode or in alternative mode.

This is an 8-bit register.

Access This register can be read/written in 8-bit and 1-bit units.

Address see "Port Group Configuration" on page 40

Initial Value 00<sub>H</sub> or 0000<sub>H</sub>. This register is initialized by RESET.

| 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|-------|-------|-------|-------|-------|-------|-------|
| PMCn7 | PMCn6 | PMCn5 | PMCn4 | PMCn3 | PMCn2 | PMCn1 | PMCn0 |
| R/W   |

#### Table 2-4 PMCn register contents

| Bit position | Bit name  | Function                                                                                     |
|--------------|-----------|----------------------------------------------------------------------------------------------|
| 7 to 0       | PMCn[7:0] | Specifies the operation mode of the corresponding pin<br>0: Port mode<br>1: Alternative mode |

**Caution** When changing the function of a port from port mode (PCMnm = 0) to external interrupt input (PCMnm = 1) an advertent interrupt may occur.

Therefore, it is recommended to follow the below procedure:

- 1. To select the alternative input function INTPn (I), set PFCE.PFCEnm and PFC.PFCnm accordingly.
- 2. Set PMCnm = 1 to change to the alternative mode.
- 3. Wait until the delay of the noise rejection filter has passed.
- 4. Set INTnIC.INTnIF = 0 to clear the interrupt request.
- 5. Clear INTnIC.INTnMK (or clear INTMR.INTnMK) to enable the interrupt.

In step 3 you must wait for a certain time span because the external interrupt pins are equipped with noise rejection filters. The filters cause a delay in which the interrupt request flag INTnIC.INTnIF is set. This flag must be cleared (step 4).



(2) PMn - Port mode register

If a pin is in port mode (PMCn.PMCnm = 0), the PMn register specifies whether the individual pins of the port group n are in input mode or in output mode.

This is an 8-bit register.

- Note If a pin is in alternative mode (PMCn.PMCnm = 1) and the corresponding PMn bit is set (PMn.PMnm = 1), then the pin behaves as in input port mode: Reading Pn.Pmn reads the pin status.
- Access This register can be read/written in 8-bit and 1-bit units.
- Address see "Port Group Configuration" on page 40
- Initial Value FF<sub>H</sub> or FFFF<sub>H</sub>. This register is initialized by RESET.

|   | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|---|------|------|------|------|------|------|------|------|
|   | PMn7 | PMn6 | PMn5 | PMn4 | PMn3 | PMn2 | PMn1 | PMn0 |
| - | R/W  |

## Table 2-5 PMn register contents

| Bit position | Bit name | Function                                                                                                                                   |
|--------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 7 to 0       | PMn[7:0] | Specifies input/output mode of the corresponding pin in<br>port mode<br>0: Output mode (output enabled)<br>1: Input mode (output disabled) |



#### (3) **PFCn - Port function control register**

If a pin is in alternative mode (PMCn.PMCnm = 1) some pins offer up to four alternative functions.

The 8-bit PFCn register together with the 8-bit PFCEn register specifies which function of a pin is to be used. The corresponding port type defines whether a pin is in input or output mode.

Access This register can be read/written in 8-bit and 1-bit units.

Address see "Port Group Configuration" on page 40

Initial Value 00<sub>H</sub>

This register is initialized by RESET.

| 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|-------|-------|-------|-------|-------|-------|-------|
| PFCn7 | PFCn6 | PFCn5 | PFCn4 | PFCn3 | PFCn2 | PFCn1 | PFCn0 |
| R/W   |

## Table 2-6 PFCn register contents

| Bit position | Bit name  | Function                             |
|--------------|-----------|--------------------------------------|
| 7 to 0       | PFCn[7:0] | See Table 2-3 on page 28 for details |

#### (4) PFCEn - Port function control expansion register

If a pin is in alternative mode (PMCn.PMCnm = 1) some pins offer up to four alternative functions.

The 8-bit PFCEn together with the PFCn register specifies which function of a pin is to be used. The corresponding port type defines whether a pin is in input or output mode.

Access This register can be read/written in 8-bit and 1-bit units.

Address see "Port Group Configuration" on page 40

Initial Value 00<sub>H</sub>

This register is initialized by RESET.

| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|--------|--------|--------|--------|--------|--------|--------|--------|
| PFCEn7 | PFCEn6 | PFCEn5 | PFCEn4 | PFCEn3 | PFCEn2 | PFCEn1 | PFCEn0 |
| R/W    |

#### Table 2-7 PFCEn register contents

| Bit position | Bit name  | Function                             |
|--------------|-----------|--------------------------------------|
| 7 to 0       | PFCn[7:0] | See Table 2-3 on page 28 for details |



# 2.2.3 Pin data input/output

If a pin is in port mode, the registers for pin data input/output specify the input and output data.

## (1) Pn - Port register

If a pin is in port mode (PMCn.PMCnm = 0), data is input from or output to an external device by writing or reading the Pn register.

This is an 8-bit register.

- Access This register can be read/written in 8-bit and 1-bit units.
- Address see "Port Group Configuration" on page 40

Initial Value Undefined.

**Note** After reset, the ports are in input mode (PMn.PMnm = 1). The read input value is determined by the port pins.

| 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|
| Pn7 | Pn6 | Pn5 | Pn4 | Pn3 | Pn2 | Pn1 | Pn0 |
| R/W |

#### Table 2-8 Pn register contents

| Bit position | Bit position Bit name Function |                                                                                     |  |  |
|--------------|--------------------------------|-------------------------------------------------------------------------------------|--|--|
| 7 to 0       | Pn[7:0]                        | Data, see <i>Table 2-9 on page 32</i> and <i>Table 2-10 on page 33</i> for details. |  |  |

**Note** The value written to register Pn is retained until a new value is written to register Pn.

**Port mode** In port mode (PMCn.PMCnm = 0), register PMn specifies whether a pin is in input or in output mode. Data is written to or read from the Pn register as follows:

## Table 2-9 Writing/reading register Pn in port mode (PMCn.PMCnm = 0)

| Function                                                              | РМ | I/O |
|-----------------------------------------------------------------------|----|-----|
| Write to Pn                                                           |    |     |
| and output contents of Pn to pins                                     | 0  | 0   |
| without affecting the pin status                                      | 1  | I   |
| Read from Pn                                                          |    |     |
| and thus read the pin status                                          | 1  | I   |
| read the data in the register Pn, and disregard the actual pin status | 0  | 0   |



Alternative mode In alternative mode (PMCn.PMCnm = 1), the corresponding port type defines whether a pin is in input or output mode. However, register PMn influences the writing/reading of register Pn.

In alternative mode, data is written to or read from the Pn register as follows:

#### Table 2-10 Writing/reading register Pn in alternative mode (PMCn.PMCnm = 1)

| Function                                                                                                       | РМ | I/O |
|----------------------------------------------------------------------------------------------------------------|----|-----|
| Write to Pn<br>without affecting the pin status                                                                | х  | -   |
| Read from Pn                                                                                                   |    |     |
| and read the value of the alternative output function (for pins in alternative output function)                |    |     |
| read the data in the register Pn, and disregard the actual pin status (for pins in alternative input function) | 0  | _   |
| and thus read the pin status                                                                                   | 1  | I   |

Caution

n Although 1-bit operations (read-modify-write operations) on Pn registers are intended to modify only a single bit, the entire Pn register is read. After the single bit has been modified, the contents of the complete register is written back.

If the ports of the register Pn contain both input and output ports Pnm, the read of Pn returns

- · the contents of the register Pn for output ports
- the pin status of input ports, but not the Pn register bits

That means the read value of Pn may be different to the contents of the Pn register at bit positions, which are assigned to input ports.

Thus the contents of Pn may differ to the previous value not just in the bit that was to be modified, but also in other bits.

Example:

- Register P1 has the contents 00<sub>H</sub>.
- Port P10 is configured as an output port, all other ports of port group 1 (ports P11 to P17) are configured as input ports.
- The port pins of ports P11 to P17 all have the level "1".
- Bit P1.P10 is set to 1 by a 1-bit operation.

Afterwards, register P1 holds the value  $FF_H$  instead of the expected value  $01_H$ , since bits P11 to P17 have be overwritten with the corresponding pin levels "1".



# 2.2.4 Emergency shut-off configuration

The emergency shut-off function sets a port immediately into high impedance state upon occurrence of two events:

- assertion of an external signal ESOm
- interrupt of the Clock Monitor INTOSD

Both events can be separately permitted respectively prohibited to trigger an emergency shut-off.

The registers for controlling the emergency shut-off are described in the following.

## (1) PESCn - Emergency shut-off control register

The 8-bit PESCn register specifies the condition of the concerned external control pin to trigger an emergency shut-off. An emergency shut-off can be generated upon edges or levels.

Writing to this register is protected by a special sequence of instructions. To enable write access to PESCn, first write to PRCMD. Please refer to *"Write Protected Registers" on page 97* for details.

Access This register can be read/written in 8-bit units.

Address see "Port Group Configuration" on page 40

Initial Value 00<sub>H</sub>. This register is initialized by RESET.

| 7 | 6 | 5 | 4 | 3      | 2 | 1       | 0       |
|---|---|---|---|--------|---|---------|---------|
| 0 | 0 | 0 | 0 | ESOmEN | 0 | ESOmED1 | ESOmED0 |
| R | R | R | R | R/W    | R | R/W     | R/W     |

#### Table 2-11 PESCn register contents

| Bit Position | Bit Name        | Function |                                                                                               |         |                             |   |             |
|--------------|-----------------|----------|-----------------------------------------------------------------------------------------------|---------|-----------------------------|---|-------------|
| 3            | ESOmEN          | ES<br>(  | Enables/disables the emergency shut-off control by<br>ESOm input<br>0: disabled<br>1: enabled |         |                             |   |             |
|              |                 |          | ets the edge o<br>ggering an en                                                               |         | t signal ESOm for<br>t-off. |   |             |
|              | ESOmED<br>[1:0] |          | ESOmED1                                                                                       | ESOmED0 | Selected edge/level         |   |             |
|              |                 |          | 0                                                                                             | 0       | falling edge                |   |             |
| 1 to 0       |                 | [1:0]    | [1:0]                                                                                         |         | 0                           | 1 | rising edge |
|              |                 |          | 1                                                                                             | 0       | low level                   |   |             |
|              |                 |          | 1                                                                                             | 1       | high level                  |   |             |
|              |                 |          |                                                                                               |         | ·                           |   |             |

Caution

n State of the edge detection control bits ESOmED1 and ESOmED0 must not be changed while ESOmEN is set to 1. Otherwise the output shut-off function may be unintentionally triggered or a trigger event may be lost.



**Note** 1. The emergency shut-off function is not dedicated to a single port of a port group, but acts on the *entire* port group. However, note that not all ports of a port group may be subject to the emergency shut-off function. Refer to the description of the concerned port group.

- If the emergency shut-off condition is fulfilled, the concerned pin is not switched to high impedance state if the port is configured as port output (PMCnm = 0, PMnm = 0).
- The output buffer of the concerned ports Pnm are forcibly disabled (high impedance output) as long as PESCn.ESOmEN and ESOSTn.ESOmST are set to 1.

Setting up an emergency shut-off The setup of the emergency shut-off function must be performed in the following sequence. Otherwise the output shut-off function may be unintentionally triggered or a trigger event may be lost.

- 1. Power on (all registers are reset)
- 2. PRCMD write (write protect released)
- 3. Clear ESOmEN bit to 0
- 4. PRCMD write (write protect released)
- 5. Set ESOmED0, ESOmED1 bits
- 6. PRCMD write (write protect released)
- 7. Clear ESOmST bit of ESOSTn register to 0
- 8. PRCMD write (write protect released)
- 9. Set PESMKnm bits to 0 respectively 1
- 10. PRCMD write (write protect released)
- 11. Set ESOmEN bit to 1



#### (2) ESOSTn - Emergency shut-off status register

The 8-bit ESOSTn register indicates the status of an emergency shut-off condition.

Writing to this register is protected by a special sequence of instructions. To enable write access to ESOSTn, first write to PRCMD. Please refer to "Write Protected Registers" on page 97 for details.

This register can be read/written in 8-bit units. Access

Address see "Port Group Configuration" on page 40

Initial Value 00<sub>H</sub>. This register is initialized by RESET.

| 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------|---|---|---|---|---|---|---|
| ESOmST | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| R/W    | R | R | R | R | R | R | R |

#### Table 2-12 ESOSTn register contents

| <b>Bit Position</b> | Bit Name | Function                                                                                                                                                                                                                                                              |
|---------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7                   | ESOmST   | <ul> <li>Specifies the level at the corresponding pin after<br/>emergency shut-off</li> <li>0: high (no emergency shut-off was triggered: pin<br/>output is active)</li> <li>1: low (emergency shut-off was triggered: pin is in high<br/>impedance state)</li> </ul> |

**Note** 1. The emergency shut-off function is not dedicated to a single port of a port group, but acts on the entire port group. However, note that not all ports of a port group may be subject to the emergency shut-off function. Refer to the description of the concerned port group.

- 2. Writing the emergency shut-off status flag (ESOmST) is only possible if PESCn.ESmEN is cleared (0).
- 3. The ESOmST flag can only be cleared by CPU to 0. Setting the ESOmST flag to 1 is not possible.
- 4. The output buffers of concerned ports Pnm are forcibly disabled (high impedance output) as long as PESCn.ESOmEN and PESCn.ESOmST are set to 1.



#### (3) PESMKn - Emergency shut-off mask register

The 8-bit PESMKn register allows to mask and unmask events to perform an emergency shut-off.

Writing to this register is protected by a special sequence of instructions. To enable write access to PESMKn, first write to PRCMD. Please refer to *"Write Protected Registers" on page 97* for details.

Access This register can be read/written in 8-bit and 1-bit units.

Address see "Port Group Configuration" on page 40

Initial Value 00<sub>H</sub>. This register is initialized by RESET.

| 7 | 6 | 5 | 4 | 3 | 2 | 1       | 0       |
|---|---|---|---|---|---|---------|---------|
| 0 | 0 | 0 | 0 | 0 | 0 | PESMKn1 | PESMKn0 |
| R | R | R | R | R | R | R       | R/W     |

#### Table 2-13 PESMKn register contents

| <b>Bit Position</b> | Bit Name | Function                                                                                                                                                                                      |
|---------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1                   | PESMKn1  | <ul> <li>Masks function of INTOSD</li> <li>0: unmasked (INTOSD can trigger an emergency<br/>shut-off)</li> <li>1: masked (INTOSD can not trigger an emergency<br/>shut-off)</li> </ul>        |
| 0                   | PESMKn0  | <ul> <li>Masks function of ESOm input signal</li> <li>0: unmasked (ESOm can trigger an emergency<br/>shut-off)</li> <li>1: masked (ESOm can not trigger an emergency<br/>shut-off)</li> </ul> |



### 2.2.5 Write enable register

Some port group configuration registers are write protected. Write access to a write protected register is only given immediately after writing to a corresponding write enable register.

#### (1) PRCMD - Command register

The 8-bit PRCMD register protects port group configuration registers from inadvertent write access, so that the system does not stop in case of a program hang-up.

After writing to the PRCMD register, you are permitted to write once to one of the protected registers. This must be done immediately after writing to the PRCMD register. After the second write action, or if the second write action does not follow immediately, all protected registers are write-locked again.

The following registers are protected by PRCMD (n = 5, 6):

| PMCn   | Port mode control register          |
|--------|-------------------------------------|
| PMn    | Port mode register                  |
| Pn     | Port register                       |
| PESCn  | Emergency shut-off control register |
| PESMKn | Emergency shut-off mask register    |
| ESOSTn | Emergency shut-off status register  |

An invalid write attempt to one of the above registers sets the error flag PHS.PRERR. PHS.PRERR is also set, if a write access to PRCMD is not immediately followed by an access to one of the protected registers.

Access This register can only be written in 8-bit units.

Address FFFF F1FC<sub>H</sub>.

**Initial Value** 

The contents of this register is undefined.





| (2)           | PHS - Per             | ripheral s                                                                                                                                                | tatus regi     | ister          |                |                |                |       |
|---------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------|----------------|----------------|----------------|-------|
|               |                       | The 8-bit PHS register indicates the status of a write attempt to a register protected by PRCMD (see also <i>"PRCMD - Command register" on page 38</i> ). |                |                |                |                |                |       |
| Access        | This regis            | ter can be                                                                                                                                                | read/writ      | ten in 8-bi    | t units.       |                |                |       |
| Address       | FFFF F80              | )2 <sub>H</sub> .                                                                                                                                         |                |                |                |                |                |       |
| Initial Value | 00 <sub>H</sub> . The | register is                                                                                                                                               | cleared b      | y any rese     | et.            |                |                |       |
|               | 7                     | 6                                                                                                                                                         | 5              | 4              | 3              | 2              | 1              | 0     |
|               | 0                     | 0                                                                                                                                                         | 0              | 0              | 0              | 0              | 0              | PRERR |
|               | R <sup>a</sup>        | R <sup>a</sup>                                                                                                                                            | R <sup>a</sup> | R <sup>a</sup> | R <sup>a</sup> | R <sup>a</sup> | R <sup>a</sup> | R/W   |

a) These bits may be written, but write is ignored.

#### Table 2-14 PHS register contents

| Bit position | Bit name | Function                                                                                                                                                                                                                 |
|--------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0            | PRERR    | <ul> <li>Write error status:</li> <li>0: Write access was successful.</li> <li>1: Write access failed.</li> <li>You can clear this bit by writing 0 to it. Setting this bit to 1 by software is not possible.</li> </ul> |

Note PHS.PRERR is set, if a write access to register PRCMD is not directly followed by a write access to one of the write-protected registers.



# 2.3 Port Group Configuration

This section provides an overview of the port groups (*Table 2-15*) and of the pin functions (*Table 2-17 on page 45*). In *Table 2-47 on page 67* it is listed how the pin functions change if the microcontroller is reset or if it is in one of the standby modes.

In the subsections, for every port group the settings of the configuration registers is listed. Further, the addresses and initial values of the configuration registers are given. See *"Port group 0" on page 51 to "Port group 11" on page 62.* 

For the port type diagrams refer to "Port Types Diagrams" on page 44.

# 2.3.1 Port group configuration lists

Table 2-15 provides an overview of the functions available at each port pin.

#### Table 2-15Port group list (1/3)

| Port group name | Port<br>name | Alternative<br>outputs | Alternative<br>inputs | Port type | Pin<br>number |
|-----------------|--------------|------------------------|-----------------------|-----------|---------------|
|                 | P00          | -                      | NMI                   | 2         | 5             |
|                 | P01          | -                      | ESO0/INTP0            | 2         | 6             |
| 0               | P02          | -                      | ESO1/INTP1            | 2         | 7             |
|                 | P03          | -                      | ADTRG0/INTP2          | 2         | 8             |
|                 | P04          | -                      | ADTRG1/INTP3          | 2         | 9             |
|                 | P10          | TOAA00                 | TIAA00/TEVTAA1        | 5-K       | 51            |
|                 | P11          | TOAA01                 | TIAA01/TTRGAA1        | 5-K       | 52            |
|                 | P12          | TOAA10                 | TIAA10/TTRGAA0        | 5-K       | 53            |
| 1               | P13          | TOAA11                 | TIAA11/TEVTAA0        | 5-K       | 54            |
|                 | P14          | TOAA20                 | TIAA20/TEVTAA3        | 5-K       | 55            |
|                 | P15          | TOAA21                 | TIAA21/TTRGAA3        | 5-K       | 60            |
|                 | P16          | TOAA30                 | TIAA30/TTRGAA2        | 5-K       | 61            |
|                 | P17          | TOAA31                 | TIAA31/TEVTAA2        | 5-K       | 62            |
|                 | P20          | TOAA40                 | TIAA40/TEVTAA5        | 5-K       | 63            |
|                 | P21          | TOAA41                 | TIAA41/TTRGAA5        | 5-K       | 64            |
|                 | P22          | TOAA50                 | TIAA50/TTRGAA4        | 5-K       | 65            |
| 0               | P23          | TOAA51                 | TIAA51/TEVTAA4        | 5-K       | 66            |
| 2               | P24          | TOAA60                 | TIAA60/TEVTAA7        | 5-K       | 67            |
|                 | P25          | TOAA61                 | TIAA61/TTRGAA7        | 5-K       | 68            |
|                 | P26          | TOAA70                 | TIAA70/TTRGAA6        | 5-K       | 69            |
|                 | P27          | TOAA71                 | TIAA71/TEVTAA6        | 5-K       | 70            |



# Table 2-15Port group list (2/3)

| Port group name | Port<br>name                      | Alternative outputs | Alternative<br>inputs   | Port type | Pin<br>number |
|-----------------|-----------------------------------|---------------------|-------------------------|-----------|---------------|
|                 | P30                               | _                   | RXDC0/INTP4             | 5-K       | 31            |
|                 | P31                               | TXDC0               | -                       | 5-K       | 32            |
|                 | P32                               | -                   | RXDC1/INTP5             | 5-K       | 33            |
| 3               | P33                               | TXDC1               | -                       | 5-K       | 39            |
| 3               | P34                               | -                   | FCRXD0                  | 5-K       | 40            |
|                 | P35                               | FCTXD0              | -                       | 5-K       | 41            |
|                 | P36                               | -                   | FCRXD1                  | 5-K       | 42            |
|                 | P37                               | FCTXD1              | -                       | 5-K       | 43            |
|                 | P40                               | -                   | SIB0                    | 5-K       | 71            |
|                 | P41                               | SOB0                | _                       | 5-K       | 72            |
| Α               | P42                               | SCKB0               | SCKB0                   | 5-K       | 73            |
| 4               | P43                               | -                   | SIB1                    | 5-K       | 21            |
|                 | P44                               | SOB1                | _                       | 5-K       | 22            |
|                 | P45                               | SCKB1               | SCKB1                   | 5-K       | 23            |
|                 | P50                               | TOS00               | -                       | 5-K       | 94            |
|                 | P51                               | TOS01               | -                       | 5-K       | 95            |
|                 | P52                               | TOS02               | _                       | 5-K       | 96            |
| F               | P53                               | TOS03               | -                       | 5-K       | 97            |
| 5               | P54                               | TOS04               | -                       | 5-K       | 98            |
|                 | P55                               | TOS05               | _                       | 5-K       | 99            |
|                 | P56                               | TOS06               | _                       | 5-K       | 100           |
|                 | P57                               | TOS07               | -                       | 5-K       | 101           |
|                 | P60                               | TOS10               | _                       | 5-K       | 102           |
|                 | P61                               | TOS11               | -                       | 5-K       | 103           |
|                 | P62                               | TOS12               | -                       | 5-K       | 104           |
| 0               | P63                               | TOS13               | _                       | 5-K       | 105           |
| 6               | P64                               | TOS14               | -                       | 5-K       | 106           |
|                 | P65                               | TOS15               | _                       | 5-K       | 107           |
|                 | P66                               | TOS16               | _                       | 5-K       | 108           |
|                 | P67                               | TOS17               | -                       | 5-K       | 111           |
|                 | P70                               | ТОТ00               | TIT00/TEVTT1<br>TENCT00 | 5-K       | 112           |
|                 | P71 TOT01 TIT01/TTRGT1<br>TENCT01 |                     | 5-K                     | 113       |               |
| 7               | P72                               | -                   | TECRT0/INTP12           | 5-K       | 114           |
| /               | P73                               | TOT10               | TIT10/TTRGT0<br>TENCT11 | 5-K       | 144           |
|                 | P74                               | TOT11               | TIT11/TEVTT0<br>TENCT10 | 5-K       | 3             |
|                 | P75                               | AFO                 | TECRT1                  | 5-K       | 4             |



| Port group<br>name | Port<br>name | Alternative<br>outputs | Alternative<br>inputs | Port type | Pin<br>number                                                                                                                                                                                                                                    |
|--------------------|--------------|------------------------|-----------------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | P80          | -                      | SIE0                  | 5-K       | 24                                                                                                                                                                                                                                               |
|                    | P81          | SOE0                   | -                     | 5-K       | 25                                                                                                                                                                                                                                               |
|                    | P82          | SCKE0                  | SCKE0                 | 5-K       | 26                                                                                                                                                                                                                                               |
| 8                  | P83          | SCSE00                 | INTP6                 | 5-K       | 27                                                                                                                                                                                                                                               |
| o                  | P84          | SCSE01                 | INTP7                 | 5-K       | 28                                                                                                                                                                                                                                               |
|                    | P85          | SCSE02                 | INTP8                 | 5-K       | 29                                                                                                                                                                                                                                               |
|                    | P86          | SCSE03                 | SSB0                  | 5-K       | 30                                                                                                                                                                                                                                               |
|                    | P90          | -                      | SIE1                  | 5-K       | 44                                                                                                                                                                                                                                               |
|                    | P91          | SOE1                   | -                     | 5-K       | 45                                                                                                                                                                                                                                               |
|                    | P92          | SCKE1                  | SCKE1                 | 5-K       | 46                                                                                                                                                                                                                                               |
| 9                  | P93          | SCSE10/SCSE04          | INTP9                 | 5-K       | 47                                                                                                                                                                                                                                               |
|                    | P94          | SCSE11/SCSE05          | INTP10                | 5-K       | 48                                                                                                                                                                                                                                               |
|                    | P95          | SCSE12/SCSE06          | INTP11                | 5-K       | 49                                                                                                                                                                                                                                               |
|                    | P96          | SCSE13/SCSE07          | SSB1                  | 5-K       | 50                                                                                                                                                                                                                                               |
|                    | P100         | TOAA80                 | TIAA80/TTRGAA8        | 5-K       | 88                                                                                                                                                                                                                                               |
| 10                 | P101         | TOAA81                 | TIAA81/TEVTAA8        | 5-K       | 91                                                                                                                                                                                                                                               |
| 10                 | P102         | TOAA90                 | TIAA90/TTRGAA9        | 5-K       | 92                                                                                                                                                                                                                                               |
|                    | P103         | TOAA91                 | TIAA91/TEVTAA9        | 5-K       | 93                                                                                                                                                                                                                                               |
|                    | P110         | -                      | TAPTS00/TEVTS0        | 5-K       | 87                                                                                                                                                                                                                                               |
|                    | P111         | -                      | TAPTS01/TTRGS0        | 5-K       | number           24           25           26           27           28           29           30           44           45           46           47           48           49           50           88           91           92           93 |
| 11                 | P112         | -                      | TAPTS02               | 5-K       | 85                                                                                                                                                                                                                                               |
|                    | P113         | -                      | TAPTS10/TEVTS1        | 5-K       | 76                                                                                                                                                                                                                                               |
|                    | P114         | -                      | TAPTS11/TTRGS1        | 5-K       | 75                                                                                                                                                                                                                                               |
|                    | P115         | -                      | TAPTS12               | 5-K       | 74                                                                                                                                                                                                                                               |

#### Table 2-15Port group list (3/3)

# 2.3.2 Non-port pins

Voltage and clock supply pins do not have general purpose I/O port functionality. Furthermore *Table 2-16* lists all other pins which do not have a port function.

|  | Table 2-16 | Non-port pins |
|--|------------|---------------|
|--|------------|---------------|

| Name  | Port type | Pin location |
|-------|-----------|--------------|
| ANIOO | 7         | 116          |
| ANI01 | 7         | 117          |
| ANI02 | 7         | 118          |
| ANI03 | 7         | 119          |
| ANI04 | 7         | 120          |
| ANI05 | 7         | 121          |
| ANI06 | 7         | 122          |
| ANI07 | 7         | 123          |



# Table 2-16 Non-port pins

| Name        | Port type | Pin location |
|-------------|-----------|--------------|
| ANI08       | 7         | 124          |
| ANI09       | 7         | 125          |
| ANI10       | 7         | 138          |
| ANI11       | 7         | 137          |
| ANI12       | 7         | 136          |
| ANI13       | 7         | 135          |
| ANI14       | 7         | 134          |
| ANI15       | 7         | 133          |
| ANI16       | 7         | 132          |
| ANI17       | 7         | 131          |
| ANI18       | 7         | 130          |
| ANI19       | 7         | 129          |
| AVREF0      | -         | 126          |
| AVREF1      | -         | 128          |
| DCK         | 2         | 16           |
| DDI         | 2         | 18           |
| DDO         | 5         | 15           |
| DMS         | 2         | 17           |
| DRST        | 2-1       | 14           |
| MODE0/FLMD1 | 2         | 81           |
| MODE1/FLMD0 | 2         | 82           |
| MODE2       | 2         | 80           |
| MODE3       | 2         | 77           |
| RESET       | 2         | 34           |





2.3.3 Port Types Diagrams

Figure 2-2 Port type diagrams



# 2.3.4 Alphabetic pin function list

Table 2-17 provides a list of all pin function names in alphabetic order.

| Pin name | I/O | Pin function                             | Port | Pin location |
|----------|-----|------------------------------------------|------|--------------|
| ADTRG0   | I   | ADC0 trigger input                       | P03  | 8            |
| ADTRG1   | I   | ADC1 trigger input                       | P04  | 9            |
| AFO      | 0   | Auxiliary frequency output               | P75  | 4            |
| ANI00    | I   | ADC inputs                               | -    | 116          |
| ANI01    |     |                                          | -    | 117          |
| ANI02    |     |                                          | -    | 118          |
| ANI03    |     |                                          | -    | 119          |
| ANI04    |     |                                          | -    | 120          |
| ANI05    |     |                                          | -    | 121          |
| ANI06    |     |                                          | -    | 122          |
| ANI07    |     |                                          | -    | 123          |
| ANI08    |     |                                          | -    | 124          |
| ANI09    |     |                                          | -    | 125          |
| ANI10    |     |                                          | -    | 138          |
| ANI11    |     |                                          | -    | 137          |
| ANI12    |     |                                          | -    | 136          |
| ANI13    |     |                                          | -    | 135          |
| ANI14    |     |                                          | -    | 134          |
| ANI15    |     |                                          | -    | 133          |
| ANI16    |     |                                          | -    | 132          |
| ANI17    |     |                                          | -    | 131          |
| ANI18    |     |                                          | -    | 130          |
| ANI19    |     |                                          | -    | 129          |
| AVDD     | _   | ADC supply voltage (3.3 V)               | -    | 127          |
| AVREF0   | _   | ADC0 reference voltage input             | -    | 126          |
| AVREF1   | -   | ADC1 reference voltage input             | -    | 128          |
| AVSS0    | -   | ADC0 ground                              | -    | 115          |
| AVSS1    | -   | ADC1 ground                              | -    | 139          |
| CVDD15   | -   | Oscillator supply voltage (1.5 V)        | -    | 11           |
| CVSS15   |     | Oscillator supply ground                 | -    | 10           |
| DCK      | I   | N-Wire interface clock                   | -    | 16           |
| DDI      | I   | N-Wire interface debug data input        | -    | 18           |
| DDO      | 0   | N-Wire interface debug data output       | -    | 15           |
| DMS      | I   | N-Wire interface debug mode select input | -    | 17           |
| DRST     | I   | N-Wire debug interface reset             | -    | 14           |
| ESO0     | I   | Emergency shut-off control of Timer TMS0 | P01  | 6            |
| ESO1     | I   | Emergency shut-off control of Timer TMS1 | P02  | 7            |
| FCRXD0   | I   | CAN0 receive data                        | P34  | 40           |

# Table 2-17 Alphabetic pin functions list (1/6)



| Pin name           | I/O | Pin function                              | Port | Pin location |
|--------------------|-----|-------------------------------------------|------|--------------|
| FCRXD1             | I   | CAN1 receive data                         | P36  | 42           |
| FCTXD0             | 0   | CAN0 transmit data                        | P35  | 41           |
| FCTXD1             | 0   | CAN1 transmit data                        | P37  | 43           |
| FLMD0<br>(= MODE1) | I   | Flash writing control                     | -    | 82           |
| FLMD1<br>(= MODE0) | I   | Flash writing control                     | -    | 81           |
| INTP0              | Ι   | External interrupts                       | P01  | 6            |
| INTP1              |     |                                           | P02  | 7            |
| INTP2              |     |                                           | P03  | 8            |
| INTP3              |     |                                           | P04  | 9            |
| INTP4              |     |                                           | P30  | 31           |
| INTP5              |     |                                           | P32  | 33           |
| INTP6              |     |                                           | P83  | 27           |
| INTP7              |     |                                           | P84  | 28           |
| INTP8              |     |                                           | P85  | 29           |
| INTP9              |     |                                           | P93  | 47           |
| INTP10             |     |                                           | P94  | 48           |
| INTP11             |     |                                           | P95  | 49           |
| INTP12             | -   |                                           | P72  | 114          |
| MODE0              | Ι   | Operating mode select pins                | -    | 81           |
| MODE1              |     |                                           | -    | 82           |
| MODE2              |     |                                           | _    | 80           |
| MODE3              |     |                                           | _    | 77           |
| NMI                | Ι   | Non-maskable interrupt                    | P00  | 5            |
| RESET              | Ι   | Reset input                               | -    | 34           |
| RXDC0              | Ι   | UARTC0 receive data                       | P30  | 31           |
| RXDC1              | I   | UARTC1 receive data                       | P32  | 33           |
| SCKB0              | I/O | Clocked Serial Interface CSIB0 clock line | P42  | 73           |
| SCKB1              | I/O | Clocked Serial Interface CSIB1 clock line | P45  | 23           |
| SCKE0              | I/O | CSIE0 clock line                          | P82  | 26           |
| SCKE1              | I/O | CSIE1 clock line                          | P92  | 46           |
| SCSE00             | 0   | CSIE0 chip selects                        | P83  | 27           |
| SCSE01             | 1   |                                           | P84  | 28           |
| SCSE02             | 1   |                                           | P85  | 29           |
| SCSE03             | 1   |                                           | P86  | 30           |
| SCSE04             | 1   |                                           | P93  | 47           |
| SCSE05             | 1   |                                           | P94  | 48           |
| SCSE06             | 1   |                                           | P95  | 49           |
| SCSE07             |     |                                           | P96  | 50           |

# Table 2-17 Alphabetic pin functions list (2/6)



| Table 2-17 | Alphabetic pin functions list (3/6) |
|------------|-------------------------------------|
|------------|-------------------------------------|

| Pin name | I/O | Pin function                    | Port | Pin location |
|----------|-----|---------------------------------|------|--------------|
| SCSE10   | 0   | CSIE1 chip selects              | P93  | 47           |
| SCSE11   |     |                                 | P94  | 48           |
| SCSE12   |     |                                 | P95  | 49           |
| SCSE13   |     |                                 | P96  | 50           |
| SIB0     | I   | CSIB0 data input                | P40  | 71           |
| SIB1     | I   | CSIB1 data input                | P43  | 21           |
| SIE0     | 1   | CSIE0 data input                | P80  | 24           |
| SIE1     | I   | CSIE1 data input                | P90  | 44           |
| SOB0     | 0   | CSIB0 data output               | P41  | 72           |
| SOB1     | 0   | CSIB1 data output               | P44  | 22           |
| SOE0     | 0   | CSIE0 data output               | P81  | 25           |
| SOE1     | 0   | CSIE1 data output               | P91  | 45           |
| SSB0     | 1   | CSIB0 serial slave select input | P86  | 30           |
| SSB1     | I   | CSIB1 serial slave select input | P96  | 50           |
| TAPTS00  | I   | Timer TMS0 trigger signals      | P110 | 87           |
| TAPTS01  |     |                                 | P111 | 86           |
| TAPTS02  |     |                                 | P112 | 85           |
| TAPTS10  | I   | Timer TMS1 trigger signals      | P113 | 76           |
| TAPTS11  |     |                                 | P114 | 75           |
| TAPTS12  |     |                                 | P115 | 74           |
| TECRT0   | I   | Timer TMT0 clear input signal   | P72  | 114          |
| TECRT1   | I   | Timer TMT1 clear input signal   | P75  | 4            |
| TENCT00  | I   | Timer TMT0 encoder input        | P70  | 112          |
| TENCT01  |     |                                 | P71  | 113          |
| TENCT10  | I   | Timer TMT1 encoder input        | P74  | 3            |
| TENCT11  |     |                                 | P73  | 144          |
| TEVTAA0  | I   | Timer TAA0 event input          | P13  | 54           |
| TEVTAA1  | I   | Timer TAA1 event input          | P10  | 51           |
| TEVTAA2  | I   | Timer TAA2 event input          | P17  | 62           |
| TEVTAA3  | I   | Timer TAA3 event input          | P14  | 55           |
| TEVTAA4  | I   | Timer TAA4 event input          | P23  | 66           |
| TEVTAA5  | I   | Timer TAA5 event input          | P20  | 63           |
| TEVTAA6  | I   | Timer TAA6 event input          | P27  | 70           |
| TEVTAA7  | I   | Timer TAA7 event input          | P24  | 67           |
| TEVTAA8  | I   | Timer TAA8 event input          | P101 | 91           |
| TEVTAA9  | I   | Timer TAA9 event input          | P103 | 93           |
| TEVTS0   | I   | Timer TMS0 event input          | P110 | 87           |
| TEVTS1   | 1   | Timer TMS1 event input          | P113 | 76           |
| TEVTT0   | I   | Timer TMT0 event input          | P74  | 3            |
| TEVTT1   | 1   | Timer TMT1 event input          | P70  | 112          |



| Pin name | I/O | Pin function                     | Port | Pin location |
|----------|-----|----------------------------------|------|--------------|
| TIAA00   | 1   | Timer TAA0 capture trigger input | P10  | 51           |
| TIAA01   |     |                                  | P11  | 52           |
| TIAA10   | I   | Timer TAA1 capture trigger input | P12  | 53           |
| TIAA11   |     |                                  | P13  | 54           |
| TIAA20   | I   | Timer TAA2 capture trigger input | P14  | 55           |
| TIAA21   |     |                                  | P15  | 60           |
| TIAA30   | I   | Timer TAA3 capture trigger input | P16  | 61           |
| TIAA31   |     |                                  | P17  | 62           |
| TIAA40   | I   | Timer TAA4 capture trigger input | P20  | 63           |
| TIAA41   |     |                                  | P21  | 64           |
| TIAA50   | I   | Timer TAA5 capture trigger input | P22  | 65           |
| TIAA51   |     |                                  | P23  | 66           |
| TIAA60   | I   | Timer TAA6 capture trigger input | P24  | 67           |
| TIAA61   |     |                                  | P25  | 68           |
| TIAA70   | I   | Timer TAA7 capture trigger input | P26  | 69           |
| TIAA71   |     |                                  | P27  | 70           |
| TIAA80   | I   | Timer TAA8 capture trigger input | P100 | 88           |
| TIAA81   |     |                                  | P101 | 91           |
| TIAA90   | I   | Timer TAA9 capture trigger input | P102 | 92           |
| TIAA91   |     |                                  | P103 | 93           |
| TIT00    | I   | Timer TMT0 capture trigger input | P70  | 112          |
| TIT01    |     |                                  | P71  | 113          |
| TIT10    | I   | Timer TMT1 capture trigger input | P73  | 144          |
| TIT11    |     |                                  | P74  | 3            |
| TOAA00   | 0   | Timer TAA0 pulse signal output   | P10  | 51           |
| TOAA01   |     |                                  | P11  | 52           |
| TOAA10   | 0   | Timer TAA1 pulse signal output   | P12  | 53           |
| TOAA11   |     |                                  | P13  | 54           |
| TOAA20   | 0   | Timer TAA2 pulse signal output   | P14  | 55           |
| TOAA21   |     |                                  | P15  | 60           |
| TOAA30   | 0   | Timer TAA3 pulse signal output   | P16  | 61           |
| TOAA31   |     |                                  | P17  | 62           |
| TOAA40   | 0   | Timer TAA4 pulse signal output   | P20  | 63           |
| TOAA41   | 7   |                                  | P21  | 64           |
| TOAA50   | 0   | Timer TAA5 pulse signal output   | P22  | 65           |
| TOAA51   | 7   |                                  | P23  | 66           |
| TOAA60   | 0   | Timer TAA6 pulse signal output   | P24  | 67           |
| TOAA61   |     |                                  | P25  | 68           |
| TOAA70   | 0   | Timer TAA7 pulse signal output   | P26  | 69           |
| TOAA71   |     |                                  | P27  | 70           |

| Table 2-17 | Alphabetic | pin functions | list (4/6) |
|------------|------------|---------------|------------|
|------------|------------|---------------|------------|



| Pin name | I/O | Pin function                                                                                              | Port | Pin location |
|----------|-----|-----------------------------------------------------------------------------------------------------------|------|--------------|
| TOAA80   | 0   | Timer TAA8 pulse signal output                                                                            | P100 | 88           |
| TOAA81   |     |                                                                                                           | P101 | 91           |
| TOAA90   | 0   | Timer TAA9 pulse signal output                                                                            | P102 | 92           |
| TOAA91   |     |                                                                                                           | P103 | 93           |
| TOS00    | 0   | Timer TMS0 pulse signal outputs                                                                           | P50  | 94           |
| TOS01    |     | Outputs TOS01 to TOS06 can be controlled by an emergency shut-off. See "Emergency shut-off configuration" | P51  | 95           |
| TOS02    |     | on page 34.                                                                                               | P52  | 96           |
| TOS03    |     |                                                                                                           | P53  | 97           |
| TOS04    |     |                                                                                                           | P54  | 98           |
| TOS05    |     |                                                                                                           | P55  | 99           |
| TOS06    |     |                                                                                                           | P56  | 100          |
| TOS07    |     |                                                                                                           | P57  | 101          |
| TOS10    | 0   | Timer TMS1 pulse signal outputs                                                                           | P60  | 102          |
| TOS11    |     | Outputs TOS11 to TOS16 can be controlled by an emergency shut-off. See "Emergency shut-off configuration" | P61  | 103          |
| TOS12    |     | on page 34.                                                                                               | P62  | 104          |
| TOS13    |     |                                                                                                           | P63  | 105          |
| TOS14    |     |                                                                                                           | P64  | 106          |
| TOS15    |     |                                                                                                           | P65  | 107          |
| TOS16    |     |                                                                                                           | P66  | 108          |
| TOS17    |     |                                                                                                           | P67  | 111          |
| TOT00    | 0   | Timer TMT0 pulse signal output                                                                            | P70  | 112          |
| TOT01    |     |                                                                                                           | P71  | 113          |
| TOT10    | 0   | Timer TMT1 pulse signal output                                                                            | P73  | 144          |
| TOT11    |     |                                                                                                           | P74  | 3            |
| TTRGAA0  | I   | Timer TAA0 trigger input                                                                                  | P12  | 53           |
| TTRGAA1  | I   | Timer TAA1 trigger input                                                                                  | P11  | 52           |
| TTRGAA2  | I   | Timer TAA2 trigger input                                                                                  | P16  | 61           |
| TTRGAA3  | I   | Timer TAA3 trigger input                                                                                  | P15  | 60           |
| TTRGAA4  | I   | Timer TAA4 trigger input                                                                                  | P22  | 65           |
| TTRGAA5  | I   | Timer TAA5 trigger input                                                                                  | P21  | 64           |
| TTRGAA6  | I   | Timer TAA6 trigger input                                                                                  | P26  | 69           |
| TTRGAA7  | I   | Timer TAA7 trigger input                                                                                  | P25  | 68           |
| TTRGAA8  | I   | Timer TAA8 trigger input                                                                                  | P100 | 88           |
| TTRGAA9  | I   | Timer TAA9 trigger input                                                                                  | P102 | 92           |
| TTRGS0   | I   | Timer TMS0 trigger input                                                                                  | P111 | 86           |
| TTRGS1   | I   | Timer TMS1 trigger input                                                                                  | P114 | 75           |
| TTRGT0   | I   | Timer TMT0 trigger input                                                                                  | P73  | 144          |
| TTRGT1   | I   | Timer TMT1 trigger input                                                                                  | P71  | 113          |
| TXDC0    | 0   | UARTC0 transmit data                                                                                      | P31  | 32           |
| TXDC1    | 0   | UARTC1 transmit data                                                                                      | P33  | 39           |

| Table 2-17 | Alphabetic | pin functions | list (5/6) |
|------------|------------|---------------|------------|
|            |            |               |            |



| Pin name | I/O | Pin function                                                                                                     | Port | Pin location                          |
|----------|-----|------------------------------------------------------------------------------------------------------------------|------|---------------------------------------|
| VDD15    | _   | Core supply voltage                                                                                              | -    | 1, 19, 37, 56,<br>79, 90, 109,<br>140 |
| VDD30    | -   | I/O supply voltage                                                                                               | -    | 36, 59, 84,<br>142                    |
| VSS15    | -   | Core supply ground                                                                                               | -    | 2, 20, 38, 57,<br>78, 89, 110,<br>141 |
| VSS30    | _   | I/O supply ground                                                                                                | -    | 35, 58, 83,<br>143                    |
| X1       | -   | Main oscillator terminals                                                                                        | -    | 12                                    |
| X2       |     | Crystal connection/external clock input for system clock oscillation (X2 opens when the external clock is input) | -    | 13                                    |

 Table 2-17
 Alphabetic pin functions list (6/6)



# 2.3.5 Port group 0

Port group 0 is an 5-bit port group. This port group is only for input alternative mode. It comprises pins for the following functions:

- Non-maskable interrupt (NMI)
- External interrupt (INTP0 to INTP3)
- Emergency shut-off control of Timer TMS (ESO0, ESO1)
- Trigger input of A/D Converter (ADTRG0, ADTRG1)

Port group 0 includes the following pins:

Table 2-18 Port group 0: pin functions and port types

| Pin functions in different modes |                               | Pin function          | Port   | Noise               | Input                 |
|----------------------------------|-------------------------------|-----------------------|--------|---------------------|-----------------------|
| Port mode                        | Alternative mode <sup>c</sup> | after reset           | type   | filter <sup>a</sup> | charact. <sup>b</sup> |
| P00 (I)                          | NMI (I)                       | P00 (I)               | 2      | Α                   | S                     |
| P01 (I)                          | ESO0 (I)/<br>INTP0 (I)        | P01 (I)               | 2      | А                   | S                     |
| P02 (I)                          | ESO1 (I)/<br>INTP1 (I)        | P02 (I)               | 2      | A                   | S                     |
| P03 (I)                          | ADTRG0 (I)/<br>INTP2 (I)      | P03 (I)               | 2      | D                   | S                     |
| P04 (I)                          | ADTRG1 (I)/<br>INTP3 (I)      | P04 (I)               | 2      | D                   | S                     |
| a) A: analog no                  | ise filter: D: digital nois   | e filter: _: no noise | filtor |                     | L                     |

A: analog noise filter; D: digital noise filter; -: no noise filter

The filters are only effective for the alternative input functions.

b) S: Schmitt trigger; nS: non-Schmitt trigger

c) Since all alternative functions are pure input functions, no PMCn register is required.

#### Table 2-19 Port group 0: configuration registers

| Register        | Address                | Initial<br>value | Used bits |   |   |     |     |     |     |     |
|-----------------|------------------------|------------------|-----------|---|---|-----|-----|-----|-----|-----|
| P0 <sup>a</sup> | FFFF F400 <sub>H</sub> |                  | 0         | 0 | 0 | P04 | P03 | P02 | P01 | P00 |

a) Note that this register is read-only since port 0 is for input only.



# 2.3.6 Port group 1

Port group 1 is an 8-bit port group. In alternative mode, it comprises pins for the following functions:

- Timer TAA0 channels (TOAA00, TOAA01, TIAA00, TIAA01, TEVTAA0, TTRGAA0)
- Timer TAA1 channels (TOAA10, TOAA11, TIAA10, TIAA11, TEVTAA1, TTRGAA1)
- Timer TAA2 channels (TOAA20, TOAA21, TIAA20, TIAA21, TEVTAA2, TTRGAA2)
- Timer TAA3 channels (TOAA30, TOAA31, TIAA30, TIAA31, TEVTAA3, TTRGAA3)

Port group 1 includes the following pins:

#### Table 2-20Port group 1: pin functions and port types

| Pi                       | n functions in differe     | nt modes              |              |                              |                                |          |
|--------------------------|----------------------------|-----------------------|--------------|------------------------------|--------------------------------|----------|
| Port mode<br>(PMCnm = 0) | Alternat<br>(PMC           | Pin<br>function       | Port<br>type | Noise<br>filter <sup>a</sup> | Input<br>charact. <sup>b</sup> |          |
|                          | Function 1<br>PFC = 0      | Function 2<br>PFC = 1 | after reset  | type                         | inter                          | onaruoti |
| P10 (I/O)                | TIAA00 (I)/<br>TEVTAA1 (I) | TOAA00 (O)            | P10 (I)      | 5-K                          | D                              | S        |
| P11 (I/O)                | TIAA01 (I)/<br>TTRGAA1 (I) | TOAA01 (O)            | P11 (I)      | 5-K                          | D                              | S        |
| P12 (I/O)                | TIAA10 (I)/<br>TTRGAA0 (I) | TOAA10 (O)            | P12 (I)      | 5-K                          | D                              | S        |
| P13 (I/O)                | TIAA11 (I)/<br>TEVTAA0 (I) | TOAA11 (O)            | P13 (I)      | 5-K                          | D                              | S        |
| P14 (I/O)                | TIAA20 (I)/<br>TEVTAA3 (I) | TOAA20 (O)            | P14 (I)      | 5-K                          | D                              | S        |
| P15 (I/O)                | TIAA21 (I)/<br>TTRGAA3 (I) | TOAA21 (O)            | P15 (I)      | 5-K                          | D                              | S        |
| P16 (I/O)                | TIAA30 (I)/<br>TTRGAA2 (I) | TOAA30 (O)            | P16 (I)      | 5-K                          | D                              | S        |
| P17 (I/O)                | TIAA31 (I)/<br>TEVTAA2 (I) | TOAA31 (O)            | P17 (I)      | 5-K                          | D                              | S        |

 A: analog noise filter; D: digital noise filter; -: no noise filter The filters are only effective for the alternative input functions.

b) S: Schmitt trigger; nS: non-Schmitt trigger

| Register | Address                | Initial<br>value | Used bit | Used bits |       |       |       |       |       |       |  |
|----------|------------------------|------------------|----------|-----------|-------|-------|-------|-------|-------|-------|--|
| PMC1     | FFFF F442 <sub>H</sub> | 00 <sub>H</sub>  | PMC17    | PMC16     | PMC15 | PMC14 | PMC13 | PMC12 | PMC11 | PMC10 |  |
| PM1      | FFFF F422 <sub>H</sub> | FF <sub>H</sub>  | PM17     | PM16      | PM15  | PM14  | PM13  | PM12  | PM11  | PM10  |  |
| PFC1     | FFFF F462 <sub>H</sub> | 00 <sub>H</sub>  | PFC17    | PFC16     | PFC15 | PFC14 | PFC13 | PFC12 | PFC11 | PFC10 |  |
| P1       | FFFF F402 <sub>H</sub> | 00 <sub>H</sub>  | P17      | P16       | P15   | P14   | P13   | P12   | P11   | P10   |  |



# 2.3.7 Port group 2

Port group 2 is an 8-bit port group. In alternative mode, it comprises pins for the following functions:

- Timer TAA4 channels (TOAA40, TOAA41, TIAA40, TIAA41, TEVTAA4, TTRGAA4)
- Timer TAA5 channels (TOAA50, TOAA51, TIAA50, TIAA51, TEVTAA5, TTRGAA5)
- Timer TAA6 channels (TOAA60, TOAA61, TIAA60, TIAA61, TEVTAA6, TTRGAA6)
- Timer TAA7 channels (TOAA70, TOAA71, TIAA70, TIAA71, TEVTAA7, TTRGAA7)

Port group 2 includes the following pins:

#### Table 2-22Port group 2: pin functions and port types

| Pi                       | n functions in differe     | nt modes              |                 |              |                              |                                |
|--------------------------|----------------------------|-----------------------|-----------------|--------------|------------------------------|--------------------------------|
| Port mode<br>(PMCnm = 0) |                            | tive mode<br>nm = 1)  | Pin<br>function | Port<br>type | Noise<br>filter <sup>a</sup> | Input<br>charact. <sup>b</sup> |
|                          | Function 1<br>PFC = 0      | Function 2<br>PFC = 1 | after reset     | type         | intor                        | onaraoti                       |
| P20 (I/O)                | TIAA40 (I)/<br>TEVTAA5 (I) | TOAA40 (O)            | P20 (I)         | 5-K          | D                            | S                              |
| P21 (I/O)                | TIAA41 (I)/<br>TTRGAA5 (I) | TOAA41 (O)            | P21 (I)         | 5-K          | D                            | S                              |
| P22 (I/O)                | TIAA50 (I)/<br>TTRGAA4 (I) | TOAA50 (O)            | P22 (I)         | 5-K          | D                            | S                              |
| P23 (I/O)                | TIAA51 (I)/<br>TEVTAA4 (I) | TOAA51 (O)            | P23 (I)         | 5-K          | D                            | S                              |
| P24 (I/O)                | TIAA60 (I)/<br>TEVTAA7 (I) | TOAA60 (O)            | P24 (I)         | 5-K          | D                            | S                              |
| P25 (I/O)                | TIAA61 (I)/<br>TTRGAA7 (I) | TOAA61 (O)            | P25 (I)         | 5-K          | D                            | S                              |
| P26 (I/O)                | TIAA70 (I)/<br>TTRGAA6 (I) | TOAA70 (O)            | P26 (I)         | 5-K          | D                            | S                              |
| P27 (I/O)                | TIAA71 (I)/<br>TEVTAA6 (I) | TOAA71 (O)            | P27 (I)         | 5-K          | D                            | S                              |

 A: analog noise filter; D: digital noise filter; -: no noise filter The filters are only effective for the alternative input functions.

b) S: Schmitt trigger; nS: non-Schmitt trigger

| Table 2-23 | Port group 2: configuration registers |
|------------|---------------------------------------|
|            |                                       |

| Register | Address                | Initial<br>value | Used bit | Used bits |       |       |       |       |       |       |  |
|----------|------------------------|------------------|----------|-----------|-------|-------|-------|-------|-------|-------|--|
| PMC2     | FFFF F444 <sub>H</sub> | 00 <sub>H</sub>  | PMC27    | PMC26     | PMC25 | PMC24 | PMC23 | PMC22 | PMC21 | PMC20 |  |
| PM2      | FFFF F424 <sub>H</sub> | FF <sub>H</sub>  | PM27     | PM26      | PM25  | PM24  | PM23  | PM22  | PM21  | PM20  |  |
| PFC2     | FFFF F464 <sub>H</sub> | 00 <sub>H</sub>  | PFC27    | PFC26     | PFC25 | PFC24 | PFC23 | PFC22 | PFC21 | PFC20 |  |
| P2       | FFFF F404 <sub>H</sub> | 00 <sub>H</sub>  | P27      | P26       | P25   | P24   | P23   | P22   | P21   | P20   |  |



### 2.3.8 Port group 3

Port group 3 is an 8-bit port group. In alternative mode, it comprises pins for the following functions:

- External interrupts (INTP4, INTP5)
- UARTC0 receive/transmit data (RXDC0, TXDC0)
- UARTC1 receive/transmit data (RXDC1, TXDC1)
- CAN0 receive/transmit data (FCRXD0, FCTXD0)
- CAN1 receive/transmit data (FCRXD1, FCTXD1)

Port group 3 includes the following pins:

#### Table 2-24 Port group 3: pin functions and port types

| Pin functions            | s in different modes            | Pin                     | Port | Noise               | Input                 |
|--------------------------|---------------------------------|-------------------------|------|---------------------|-----------------------|
| Port mode<br>(PMCnm = 0) | Alternative mode<br>(PMCnm = 1) | function<br>after reset | type | filter <sup>a</sup> | charact. <sup>b</sup> |
| P30 (I/O)                | RXDC0 (I)/<br>INTP4 (I)         | P30 (I)                 | 5-K  | D                   | S                     |
| P31 (I/O)                | TXDC0 (O)                       | P31 (I)                 | 5-K  | -                   | S                     |
| P32 (I/O)                | RXDC1 (I)/<br>INTP5 (I)         | P32 (I)                 | 5-K  | D                   | S                     |
| P33 (I/O)                | TXDC1 (O)                       | P33 (I)                 | 5-K  | -                   | S                     |
| P34 (I/O)                | FCRXD0 (I)                      | P34 (I)                 | 5-K  | -                   | S                     |
| P35 (I/O)                | FCTXD0 (O)                      | P35 (I)                 | 5-K  | -                   | S                     |
| P36 (I/O)                | FCRXD1 (I)                      | P36 (I)                 | 5-K  | -                   | S                     |
| P37 (I/O)                | FCTXD1 (O)                      | P37 (I)                 | 5-K  | _                   | S                     |

a) A: analog noise filter; D: digital noise filter; -: no noise filter

The filters are only effective for the alternative input functions.

b) S: Schmitt trigger; nS: non-Schmitt trigger

 Table 2-25
 Port group 3: configuration registers

| Register | Address                | Initial<br>value | Used bit | Used bits |       |       |       |       |       |       |
|----------|------------------------|------------------|----------|-----------|-------|-------|-------|-------|-------|-------|
| PMC3     | FFFF F446 <sub>H</sub> | 00 <sub>H</sub>  | PMC37    | PMC36     | PMC35 | PMC34 | PMC33 | PMC32 | PMC31 | PMC30 |
| PM3      | FFFF F426 <sub>H</sub> | FF <sub>H</sub>  | PM37     | PM36      | PM35  | PM34  | PM33  | PM32  | PM31  | PM30  |
| P3       | FFFF F406 <sub>H</sub> | 00 <sub>H</sub>  | P37      | P36       | P35   | P34   | P33   | P32   | P31   | P30   |



# 2.3.9 Port group 4

Port group 4 is a 6-bit port group. In alternative mode, it comprises pins for the following functions:

- Clocked Serial Interface CSIB0 data/clock line (SIB0, SOB0, SCKB0)
- Clocked Serial Interface CSIB1 data/clock line (SIB1, SOB1, SCKB1)

Port group 4 includes the following pins:

#### Table 2-26 Port group 4: pin functions and port types

| Pin functions            | s in different modes            | Pin                     | Port     | Noise               | Input                 |
|--------------------------|---------------------------------|-------------------------|----------|---------------------|-----------------------|
| Port mode<br>(PMCnm = 0) | Alternative mode<br>(PMCnm = 1) | function<br>after reset | type     | filter <sup>a</sup> | charact. <sup>b</sup> |
| P40 (I/O)                | SIB0 (I)                        | P40 (I)                 | 5-K      | -                   | S                     |
| P41 (I/O)                | SOB0 (O)                        | P41 (I)                 | 5-K      | -                   | S                     |
| P42 (I/O)                | SCKB0 (I/O)                     | P42 (I)                 | 5-K      | -                   | S                     |
| P43 (I/O)                | SIB1 (I)                        | P43 (I)                 | 5-K      | -                   | S                     |
| P44 (I/O)                | SOB1 (O)                        | P44 (I)                 | 5-K      | -                   | S                     |
| P45 (I/O)                | SCKB1 (I/O)                     | P45 (I)                 | 5-K      | -                   | S                     |
| a) A: analog r           | noise filter; D: digital nois   | se filter: –: no nois   | e filter | •                   |                       |

A: analog noise filter; D: digital noise filter; -: no noise filter

The filters are only effective for the alternative input functions.

b) S: Schmitt trigger; nS: non-Schmitt trigger

#### Table 2-27 Port group 4: configuration registers

| Register | Address                | Initial<br>value | Used bit | s |       |       |       |       |       |       |
|----------|------------------------|------------------|----------|---|-------|-------|-------|-------|-------|-------|
| PMC4     | FFFF F448 <sub>H</sub> | 00 <sub>H</sub>  | 0        | 0 | PMC45 | PMC44 | PMC43 | PMC42 | PMC41 | PMC40 |
| PM4      | FFFF F428 <sub>H</sub> | FF <sub>H</sub>  | 1        | 1 | PM45  | PM44  | PM43  | PM42  | PM41  | PM40  |
| P4       | FFFF F408 <sub>H</sub> | 00 <sub>H</sub>  | 0        | 0 | P45   | P44   | P43   | P42   | P41   | P40   |



## 2.3.10 Port group 5

Port group 5 is an 8-bit port group. In alternative mode, it comprises pins for the following functions:

- Timer TMS0 pulse signal output (TOS00 to TOS07)
- **Note** The outputs TOS01 to TOS06 of timer TMS0 can be controlled by an emergency shut-off. See *"Emergency shut-off configuration" on page 34* for details.

Port group 5 includes the following pins:

 Table 2-28
 Port group 5: pin functions and port types

| Pin functions            | s in different modes            | Pin                     | Port                     | Noise | Input                 |
|--------------------------|---------------------------------|-------------------------|--------------------------|-------|-----------------------|
| Port mode<br>(PMCnm = 0) | Alternative mode<br>(PMCnm = 1) | function<br>after reset | type filter <sup>a</sup> |       | charact. <sup>b</sup> |
| P50 (I/O)                | TOS00 (O)                       | P50 (I)                 | 5-K                      | -     | S                     |
| P51 (I/O)                | TOS01 (O) <sup>c</sup>          | P51 (I)                 | 5-K                      | -     | S                     |
| P52 (I/O)                | TOS02 (O) <sup>c</sup>          | P52 (I)                 | 5-K                      | -     | S                     |
| P53 (I/O)                | TOS03 (O) <sup>c</sup>          | P53 (I)                 | 5-K                      | -     | S                     |
| P54 (I/O)                | TOS04 (O) <sup>c</sup>          | P54 (I)                 | 5-K                      | -     | S                     |
| P55 (I/O)                | TOS05 (O) <sup>c</sup>          | P55 (I)                 | 5-K                      | -     | S                     |
| P56 (I/O)                | TOS06 (O) <sup>c</sup>          | P56 (I)                 | 5-K                      | -     | S                     |
| P57 (I/O)                | TOS07 (O)                       | P57 (I)                 | 5-K                      | -     | S                     |

a) A: analog noise filter; D: digital noise filter; –: no noise filter

The filters are only effective for the alternative input functions.

<sup>b)</sup> S: Schmitt trigger; nS: non-Schmitt trigger

c) Subject to emergency shut-off function

Table 2-29Port group 5: configuration registers

| Register | Address                | Initial<br>value | Used bit | Used bits |       |       |        |       |         |         |  |
|----------|------------------------|------------------|----------|-----------|-------|-------|--------|-------|---------|---------|--|
| PMC5     | FFFF F44A <sub>H</sub> | 00 <sub>H</sub>  | PMC57    | PMC56     | PMC55 | PMC54 | PMC53  | PMC52 | PMC51   | PMC50   |  |
| PM5      | FFFF F42A <sub>H</sub> | FF <sub>H</sub>  | PM57     | PM56      | PM55  | PM54  | PM53   | PM52  | PM51    | PM50    |  |
| P5       | FFFF F40A <sub>H</sub> | 00 <sub>H</sub>  | P57      | P56       | P55   | P54   | P53    | P52   | P51     | P50     |  |
| PESC5    | FFFF F888 <sub>H</sub> | 00 <sub>H</sub>  | 0        | 0         | 0     | 0     | ESO0EN | 0     | ESO0ED1 | ESO0ED0 |  |
| ESOST5   | FFFF F88A <sub>H</sub> | 00 <sub>H</sub>  | ESO0ST   | 0         | 0     | 0     | 0      | 0     | 0       | 0       |  |
| PESMK5   | FFFF F890 <sub>H</sub> | 00 <sub>H</sub>  | 0        | 0         | 0     | 0     | 0      | 0     | PESMK51 | PESMK50 |  |

Access All 8-bit registers can be accessed in 8-bit or 1-bit units.

**Note** Writing to registers PMC5, PM5, P5, PESC5, ESOST5 and RESMK5 is protected by a special sequence of instructions. Please refer to *"Write enable register" on page 38* for details.



## 2.3.11 Port group 6

Port group 6 is an 8-bit port group. In alternative mode, it comprises pins for the following functions:

- Timer TMS1 pulse signal output (TOS10 to TOS17)
- **Note** The outputs TOS11 to TOS16 of timer TMS1 can be controlled by an emergency shut-off. See *"Emergency shut-off configuration" on page 34* for details.

Port group 6 includes the following pins:

 Table 2-30
 Port group 6: pin functions and port types

| Pin functions            | s in different modes            | Pin                     | Port                     | Noise | Input                 |
|--------------------------|---------------------------------|-------------------------|--------------------------|-------|-----------------------|
| Port mode<br>(PMCnm = 0) | Alternative mode<br>(PMCnm = 1) | function<br>after reset | type filter <sup>a</sup> |       | charact. <sup>b</sup> |
| P60 (I/O)                | TOS10 (O)                       | P60 (I)                 | 5-K                      | -     | S                     |
| P61 (I/O)                | TOS11 (O) <sup>c</sup>          | P61 (I)                 | 5-K                      | -     | S                     |
| P62 (I/O)                | TOS12 (O) <sup>c</sup>          | P62 (I)                 | 5-K                      | -     | S                     |
| P63 (I/O)                | TOS13 (O) <sup>c</sup>          | P63 (I)                 | 5-K                      | -     | S                     |
| P64 (I/O)                | TOS14 (O) <sup>c</sup>          | P64 (I)                 | 5-K                      | -     | S                     |
| P65 (I/O)                | TOS15 (O) <sup>c</sup>          | P65 (I)                 | 5-K                      | -     | S                     |
| P66 (I/O)                | TOS16 (O) <sup>c</sup>          | P66 (I)                 | 5-K                      | -     | S                     |
| P67 (I/O)                | TOS17 (O)                       | P67 (I)                 | 5-K                      | -     | S                     |

a) A: analog noise filter; D: digital noise filter; -: no noise filter

The filters are only effective for the alternative input functions.

b) S: Schmitt trigger; nS: non-Schmitt trigger

c) Subject to emergency shut-off function

Table 2-31Port group 6: configuration registers

| Register | Address                | Initial<br>value | Used bit | Used bits |       |       |        |       |         |         |  |
|----------|------------------------|------------------|----------|-----------|-------|-------|--------|-------|---------|---------|--|
| PMC6     | FFFF F44C <sub>H</sub> | 00 <sub>H</sub>  | PMC67    | PMC66     | PMC65 | PMC64 | PMC63  | PMC62 | PMC61   | PMC60   |  |
| PM6      | FFFF F42C <sub>H</sub> | FF <sub>H</sub>  | PM67     | PM66      | PM65  | PM64  | PM63   | PM62  | PM61    | PM60    |  |
| P6       | FFFF F40C <sub>H</sub> | 00 <sub>H</sub>  | P67      | P66       | P65   | P64   | P63    | P62   | P61     | P60     |  |
| PESC6    | FFFF F88C <sub>H</sub> | 00 <sub>H</sub>  | 0        | 0         | 0     | 0     | ESO1EN | 0     | ESO1ED1 | ESO1ED0 |  |
| ESOST6   | FFFF F88E <sub>H</sub> | 00 <sub>H</sub>  | ESO1ST   | 0         | 0     | 0     | 0      | 0     | 0       | 0       |  |
| PESMK6   | FFFF F892 <sub>H</sub> | 00 <sub>H</sub>  | 0        | 0         | 0     | 0     | 0      | 0     | PESMK61 | PESMK60 |  |

Access All 8-bit registers can be accessed in 8-bit or 1-bit units.

**Note** Writing to registers PMC6, PM6, P6, PESC6, ESOST6 and and RESMK6 is protected by a special sequence of instructions. Please refer to *"Write enable register" on page 38* for details.



# 2.3.12 Port group 7

Port group 7 is a 6-bit port group. In alternative mode, it comprises pins for the following functions:

- Timer TMT0 channels (TIT00, TIT01, TOT00, TOT01, TEVTT0, TTRGT0, TECRT0, TENCT00, TENCT01)
- Timer TMT1 channels (TIT10, TIT11, TOT10, TOT11, TEVTT1, TTRGT1, TECRT1, TENCT10, TENCT11)
- External interrupt (INTP12)
- Auxiliary frequency output (AFO)

Port group 7 includes the following pins:

| Table 2-32 | Port group 7: pin functions and port types |
|------------|--------------------------------------------|
|------------|--------------------------------------------|

| Pi                       | n functions in differen                  |                       |              |                                         |                                |       |
|--------------------------|------------------------------------------|-----------------------|--------------|-----------------------------------------|--------------------------------|-------|
| Port mode<br>(PMCnm = 0) | Alternati<br>(PMCn                       | Pin<br>function       | Port<br>type | Noise<br>filter <sup>a</sup>            | Input<br>charact. <sup>b</sup> |       |
|                          | Function 1<br>PFC = 0                    | Function 2<br>PFC = 1 | after reset  | .,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |                                | ••••• |
| P70 (I/O)                | TIT00 (I)/<br>TEVTT1 (I)/<br>TENCT00 (I) | ТОТ00 (О)             | P70 (I)      | 5-K                                     | D                              | S     |
| P71 (I/O)                | TIT01 (I)/<br>TTRGT1 (I)/<br>TENCT01 (I) | TOT01 (O)             | P71 (I)      | 5-K                                     | D                              | S     |
| P72 (I/O)                | TECRT0 (I)                               | INTP12 (I)            | P72 (I)      | 5-K                                     | D                              | S     |
| P73 (I/O)                | TIT10 (I)/<br>TTRGT0 (I)/<br>TENCT11 (I) | TOT10 (O)             | P73 (I)      | 5-K                                     | D                              | S     |
| P74 (I/O)                | TIT11 (I)/<br>TEVTT0 (I)/<br>TENCT10 (I) | TOT11 (O)             | P74 (I)      | 5-K                                     | D                              | S     |
| P75 (I/O)                | TECRT1 (I)                               | AFO (O)               | P75 (I)      | 5-K                                     | D                              | S     |

a) A: analog noise filter; D: digital noise filter; -: no noise filter

The filters are only effective for the alternative input functions.

b) S: Schmitt trigger; nS: non-Schmitt trigger

|  | Table 2-33 | Port group 7: configuration registers |
|--|------------|---------------------------------------|
|--|------------|---------------------------------------|

| Register | Address                | Initial<br>value | Used bit | s |       |       |       |       |       |       |
|----------|------------------------|------------------|----------|---|-------|-------|-------|-------|-------|-------|
| PMC7     | FFFF F44E <sub>H</sub> | 00 <sub>H</sub>  | 0        | 0 | PMC75 | PMC74 | PMC73 | PMC72 | PMC71 | PMC70 |
| PM7      | FFFF F42E <sub>H</sub> | FF <sub>H</sub>  | 1        | 1 | PM75  | PM74  | PM73  | PM72  | PM71  | PM70  |
| PFC7     | FFFF F46E <sub>H</sub> | 00 <sub>H</sub>  | 0        | 0 | PFC75 | PFC74 | PFC73 | PFC72 | PFC71 | PFC70 |
| P7       | FFFF F40E <sub>H</sub> | 00 <sub>H</sub>  | 0        | 0 | P75   | P74   | P73   | P72   | P71   | P70   |



# 2.3.13 Port group 8

Port group 8 is a 7-bit port group. In alternative mode, it comprises pins for the following functions:

- Clocked Serial Interface CSIE0 data/clock line (SIE0, SOE0, SCKE0)
- Clocked Serial Interface CSIE0 chip select signal (SSCSE00 to SCSE03)
- Clocked Serial Interface CSIB0 serial slave select input (SSB0)
- External interrupts (INTP6 to INTP8)

Port group 8 includes the following pins:

| Table 2-34 Port group 8: pin functions and port typ |
|-----------------------------------------------------|
|-----------------------------------------------------|

| Pi                       | in functions in differen |                       |                 |                                         |                              |                                |
|--------------------------|--------------------------|-----------------------|-----------------|-----------------------------------------|------------------------------|--------------------------------|
| Port mode<br>(PMCnm = 0) |                          | ive mode<br>nm = 1)   | Pin<br>function | Port<br>type                            | Noise<br>filter <sup>a</sup> | Input<br>charact. <sup>b</sup> |
|                          | Function 1<br>PFC = 0    | Function 2<br>PFC = 1 | after reset     | .,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, |                              |                                |
| P80 (I/O)                | SIE0 (I)                 | prohibited            | P80 (I)         | 5-K                                     | -                            | S                              |
| P81 (I/O)                | SOE0 (O)                 | prohibited            | P81 (I)         | 5-K                                     | -                            | S                              |
| P82 (I/O)                | SCKE0 (I/O)              | prohibited            | P82 (I)         | 5-K                                     | -                            | S                              |
| P83 (I/O)                | SCSE00 (O)               | INTP6 (I)             | P83 (I)         | 5-K                                     | D                            | S                              |
| P84 (I/O)                | SCSE01 (O)               | INTP7 (I)             | P84 (I)         | 5-K                                     | D                            | S                              |
| P85 (I/O)                | SCSE02 (O)               | INTP8 (I)             | P85 (I)         | 5-K                                     | D                            | S                              |
| P86 (I/O)                | SCSE03 (O)               | SSB0 (I)              | P86 (I)         | 5-K                                     | -                            | S                              |

a) A: analog noise filter; D: digital noise filter; –: no noise filter

The filters are only effective for the alternative input functions.

b) S: Schmitt trigger; nS: non-Schmitt trigger

#### Table 2-35 Port group 8: configuration registers

| Register | Address                | Initial<br>value | Used bit | S     |       |       |       |       |       |       |
|----------|------------------------|------------------|----------|-------|-------|-------|-------|-------|-------|-------|
| PMC8     | FFFF F450 <sub>H</sub> | 00 <sub>H</sub>  | 0        | PMC86 | PMC85 | PMC84 | PMC83 | PMC82 | PMC81 | PMC80 |
| PM8      | FFFF F430 <sub>H</sub> | FF <sub>H</sub>  | 1        | PM86  | PM85  | PM84  | PM83  | PM82  | PM81  | PM80  |
| PFC8     | FFFF F470 <sub>H</sub> | 00 <sub>H</sub>  | 0        | PFC86 | PFC85 | PFC84 | PFC83 | 0     | 0     | 0     |
| P8       | FFFF F410 <sub>H</sub> | 00 <sub>H</sub>  | 0        | P86   | P85   | P84   | P83   | P82   | P81   | P80   |



### 2.3.14 Port group 9

Port group 9 is a 7-bit port group. In alternative mode, it comprises pins for the following functions:

- Clocked Serial Interface CSIE0 chip select signal (SCSE04 to SCSE07)
- Clocked Serial Interface CSIE1 data/clock line (SIE1, SOE1, SCKE1)
- Clocked Serial Interface CSIE1 chip select signal (SCSE10 to SCSE13)
- Clocked Serial Interface CSIB1 serial slave select input (SSB1)
- External interrupt (INTP9 to INTP11)

Port group 9 includes the following pins:

| Table 2-36 Pc | ort group 9: pin | functions and | port types |
|---------------|------------------|---------------|------------|
|---------------|------------------|---------------|------------|

|                          | Pin functio           |                       |                       |                       |             |       |                     |                       |
|--------------------------|-----------------------|-----------------------|-----------------------|-----------------------|-------------|-------|---------------------|-----------------------|
| Port mode<br>(PMCnm = 0) |                       | Alternativ<br>(PMCni  | Pin<br>function       | Port                  | Noise       | Input |                     |                       |
|                          | PFCE                  | Ξ = 0                 | PFCE                  | E = 1                 | after reset | type  | filter <sup>a</sup> | charact. <sup>b</sup> |
|                          | Function 1<br>PFC = 0 | Function 2<br>PFC = 1 | Function 3<br>PFC = 0 | Function 4<br>PFC = 1 |             |       |                     |                       |
| P90 (I/O)                | SIE1 (I)              | prohibited            | prohibited            | prohibited            | P90 (I)     | 5-K   | -                   | S                     |
| P91 (I/O)                | SOE1 (O)              | prohibited            | prohibited            | prohibited            | P91 (I)     | 5-K   | -                   | S                     |
| P92 (I/O)                | SCKE1 (I/O)           | prohibited            | prohibited            | prohibited            | P92 (I)     | 5-K   | -                   | S                     |
| P93 (I/O)                | SCSE10 (O)            | INTP9 (I)             | SCSE04 (O)            | prohibited            | P93 (I)     | 5-K   | D                   | S                     |
| P94 (I/O)                | SCSE11 (O)            | INTP10 (I)            | SCSE05 (O)            | prohibited            | P94 (I)     | 5-K   | D                   | S                     |
| P95 (I/O)                | SCSE12 (O)            | INTP11 (I)            | SCSE06 (O)            | prohibited            | P95 (I)     | 5-K   | D                   | S                     |
| P96 (I/O)                | SCSE13 (O)            | SSB1 (I)              | SCSE07 (O)            | prohibited            | P96 (I)     | 5-K   | _                   | S                     |

a) A: analog noise filter; D: digital noise filter; -: no noise filter

The filters are only effective for the alternative input functions.

b) S: Schmitt trigger; nS: non-Schmitt trigger

| Table 2-37 | Port group 9: configuration registers |
|------------|---------------------------------------|
|            | i on group 5. configuration registers |

| Register | Address                | Initial<br>value | Used bit | S      |        |        |        |       |       |       |
|----------|------------------------|------------------|----------|--------|--------|--------|--------|-------|-------|-------|
| PMC9     | FFFF F452 <sub>H</sub> | 00 <sub>H</sub>  | 0        | PMC96  | PMC95  | PMC94  | PMC93  | PMC92 | PMC91 | PMC90 |
| PM9      | FFFF F432 <sub>H</sub> | FF <sub>H</sub>  | 1        | PM96   | PM95   | PM94   | PM93   | PM92  | PM91  | PM90  |
| PFC9     | FFFF F472 <sub>H</sub> | 00 <sub>H</sub>  | 0        | PFC96  | PFC95  | PFC94  | PFC93  | 0     | 0     | 0     |
| PFCE9    | FFFF FC32 <sub>H</sub> | 00 <sub>H</sub>  | 0        | PFCE96 | PFCE95 | PFCE94 | PFCE93 | 0     | 0     | 0     |
| P9       | FFFF F412 <sub>H</sub> | 00 <sub>H</sub>  | 0        | P96    | P95    | P94    | P93    | P92   | P91   | P90   |



# 2.3.15 Port group 10

Port group 10 is a 4-bit port group. In alternative mode, it comprises pins for the following functions:

- Timer TAA8 channels (TOAA80, TOAA81, TIAA80, TIAA81, TEVTAA8, TTRGAA8)
- Timer TAA9 channels (TOAA90, TOAA91, TIAA90, TIAA91, TEVTAA9, TTRGAA9)

Port group 10 includes the following pins:

| Table 2-38 | Port group 10: pin functions and port types |
|------------|---------------------------------------------|
|------------|---------------------------------------------|

| P                        | in functions in differen   |                       |                 |              |                              |                                |  |
|--------------------------|----------------------------|-----------------------|-----------------|--------------|------------------------------|--------------------------------|--|
| Port mode<br>(PMCnm = 0) |                            | ive mode<br>nm = 1)   | Pin<br>function | Port<br>type | Noise<br>filter <sup>a</sup> | Input<br>charact. <sup>b</sup> |  |
|                          | Function 1<br>PFC = 0      | Function 2<br>PFC = 1 | after reset     | , ypc        | inter                        | onardoti                       |  |
| P100 (I/O)               | TIAA80 (I)/<br>TTRGAA8 (I) | TOAA80 (O)            | P100 (I)        | 5-K          | D                            | S                              |  |
| P101 (I/O)               | TIAA81 (I)/<br>TEVTAA8 (I) | TOAA81 (O)            | P101 (I)        | 5-K          | D                            | S                              |  |
| P102 (I/O)               | TIAA90 (I)/<br>TTRGAA9 (I) | TOAA90 (O)            | P102 (I)        | 5-K          | D                            | S                              |  |
| P103 (I/O)               | TIAA91 (I)/<br>TEVTAA9 (I) | TOAA91 (O)            | P103 (I)        | 5-K          | D                            | S                              |  |

a) A: analog noise filter; D: digital noise filter; -: no noise filter

The filters are only effective for the alternative input functions.

b) S: Schmitt trigger; nS: non-Schmitt trigger.

 Table 2-39
 Port group 10: configuration registers

| Register | Address                | Initial<br>value | Used bit | s |   |   |        |        |        |        |
|----------|------------------------|------------------|----------|---|---|---|--------|--------|--------|--------|
| PMC10    | FFFF F454 <sub>H</sub> | 00 <sub>H</sub>  | 0        | 0 | 0 | 0 | PMC103 | PMC102 | PMC101 | PMC100 |
| PM10     | FFFF F434 <sub>H</sub> | FF <sub>H</sub>  | 1        | 1 | 1 | 1 | PM103  | PM102  | PM101  | PM100  |
| PFC10    | FFFF F474 <sub>H</sub> | 00 <sub>H</sub>  | 0        | 0 | 0 | 0 | PFC103 | PFC102 | PFC101 | PFC100 |
| P10      | FFFF F414 <sub>H</sub> | 00 <sub>H</sub>  | 0        | 0 | 0 | 0 | P103   | P102   | P101   | P100   |



# 2.3.16 Port group 11

Port group 11 is a 6-bit port group. In alternative mode, it comprises pins for the following functions:

- Timer TMS0 input channels (TAPTS00 to TAPTS02, TEVTS0, TTRGS0)
- Timer TMS1 input channels (TAPTS10 to TAPTS12, TEVTS1, TTRGS1)

Port group 11 includes the following pins:

#### Table 2-40 Port group 11: pin functions and port types

| Pin functions            | Pin functions in different modes |                         | Port   | Noise               | Input                          |
|--------------------------|----------------------------------|-------------------------|--------|---------------------|--------------------------------|
| Port mode<br>(PMCnm = 0) | Alternative mode<br>(PMCnm = 1)  | function<br>after reset | type   | filter <sup>a</sup> | Input<br>charact. <sup>b</sup> |
| P110 (I/O)               | TAPTS00 (I)/<br>TEVTS0 (I)       | P110 (I)                | 5-K    | D                   | S                              |
| P111 (I/O)               | TAPTS01 (I)/<br>TTRGS0 (I)       | P111 (I)                | 5-K    | D                   | S                              |
| P112 (I/O)               | TAPTS02 (I)                      | P112 (I)                | 5-K    | D                   | S                              |
| P113 (I/O)               | TAPTS10 (I)/<br>TEVTS1 (I)       | P113 (I)                | 5-K    | D                   | S                              |
| P114 (I/O)               | TAPTS11 (I)/<br>TTRGS1 (I)       | P114 (I)                | 5-K    | D                   | S                              |
| P115 (I/O)               | TAPTS12 (I)                      | P115 (l)                | 5-K    | D                   | S                              |
| a) A: analog n           | oise filter; D: digital nois     | e filter: -: no noise   | filter |                     |                                |

The filters are only effective for the alternative input functions.

b) S: Schmitt trigger; nS: non-Schmitt trigger

Table 2-41 Port group 11: configuration registers

| Register | Address                | Initial<br>value | Used bit | s |        |        |        |        |        |        |
|----------|------------------------|------------------|----------|---|--------|--------|--------|--------|--------|--------|
| PMC11    | FFFF F456 <sub>H</sub> | 00 <sub>H</sub>  | 0        | 0 | PMC115 | PMC114 | PMC113 | PMC112 | PMC111 | PMC110 |
| PM11     | FFFF F436 <sub>H</sub> | FF <sub>H</sub>  | 1        | 1 | PM115  | PM114  | PM113  | PM112  | PM111  | PM110  |
| P11      | FFFF F416 <sub>H</sub> | 00 <sub>H</sub>  | 0        | 0 | P115   | P114   | P113   | P112   | P111   | P110   |



# 2.4 Noise Elimination

The input signals at some pins are passing a filter to remove noise and glitches. The microcontroller supports both analog and digital filters.

If the pins are used as general purpose I/O ports Pmn, the signals are not filtered.

Following alternative function signals are not filtered at the ports:

- UARTCn receive data signals RXDCn, but UARTCn has built-in noise rejection filters
- CANn receive data signals FCRXDn
- CSIBn signals: SCKBn, SIBn, SSBn
- CSIEn signals: SCKEn, SIEn

In the following all signals are listed, which are filtered.

The port group functions tables in section *"Port group 0" on page 51* and all following also indicate filtered signals.

## 2.4.1 Analog filtered inputs

The analog filter suppresses input pulses that are shorter than a specified pulse width (refer to the Data Sheet). This assures the hold time for the external interrupt signals.

The analog filter is not effective if the corresponding pin works as a general purpose I/O port.

*Table 2-42* lists all signals which are passed through an analog filter to remove noise and glitches.

#### Table 2-42 Input signals with analog filters

| Function   | Pin name       | Inputs with analog filter |
|------------|----------------|---------------------------|
| Reset      | RESET          | RESET                     |
|            | DRST           | DRST                      |
| Interrupts | P00/NMI        | NMI                       |
|            | P01/ESO0/INTP0 | ESO0/INTP0                |
|            | P02/ESO1/INTP1 | ESO1/INTP1                |



Chapter 2

# 2.4.2 Digitally filtered inputs

The inputs of the peripherals listed in *Table 2-43* are passed through a digital filter to remove noise and glitches.

The digital filter is not effective if the corresponding pin works as a general purpose I/O port.

#### Table 2-43 Input signals with digital filters (1/2)

| Function   | Pin name                   | Inputs with digital filter |
|------------|----------------------------|----------------------------|
| Interrupts | P03/ADTRG0/INTP2           | ADTRG0/INTP2               |
|            | P04/ADTRG1/INTP3           | ADTRG1/INTP3               |
|            | P30/RXDC0/INTP4            | INTP4                      |
|            | P32/RXDC1/INTP5            | INTP5                      |
|            | P83/SCSE00/INTP6           | INTP6                      |
|            | P84/SCSE01/INTP7           | INTP7                      |
|            | P85/SCSE02/INTP8           | INTP8                      |
|            | P93/SCSE10/INTP9/SCSE04    | INTP9                      |
|            | P94/SCSE11/INTP10/SCSE05   | INTP10                     |
|            | P95/SCSE12/INTP11/SCSE06   | INTP11                     |
|            | P72/TECRT0/INTP12          | TECRT0/INTP12              |
| Timers A   | P10/TIAA00/TEVTAA1/TOAA00  | TIAA00/TEVTAA1             |
|            | P11/TIAA01/TTRGAA1/TOAA01  | TIAA01/TTRGAA1             |
|            | P12/TIAA10/TTRGAA0/TOAA10  | TIAA10/TTRGAA0             |
|            | P13/TIAA11/TEVTAA0/TOAA11  | TIAA11/TEVTAA0             |
|            | P14/TIAA20/TEVTAA3/TOAA20  | TIAA11/TEVTAA0             |
|            | P15/TIAA21/TTRGAA3/TOAA21  | TIAA21/TTRGAA3             |
|            | P16/TIAA30/TTRGAA2/TOAA30  | TIAA30/TTRGAA2             |
|            | P17/TIAA31/TEVTAA2/TOAA31  | TIAA31/TEVTAA2             |
|            | P20/TIAA40/TEVTAA5/TOAA40  | TIAA40/TEVTAA5             |
|            | P21/TIAA41/TTRGAA5/TOAA41  | TIAA41/TTRGAA5             |
|            | P22/TIAA50/TTRGAA4/TOAA50  | TIAA41/TTRGAA5             |
|            | P23/TIAA51/TEVTAA4/TOAA51  | TIAA51/TEVTAA4             |
|            | P24/TIAA60/TEVTAA7/TOAA60  | TIAA60/TEVTAA7             |
|            | P25/TIAA61/TTRGAA7/TOAA61  | TIAA61/TTRGAA7             |
|            | P26/TIAA70/TTRGAA6/TOAA70  | TIAA70/TTRGAA6             |
|            | P27/TIAA71/TEVTAA6/TOAA71  | TIAA71/TEVTAA6             |
|            | P100/TIAA80/TTRGAA8/TOAA80 | TIAA80/TTRGAA8             |
|            | P101/TIAA81/TEVTAA8/TOAA81 | TIAA81/TEVTAA8             |
|            | P102/TIAA90/TTRGAA9/TOAA90 | TIAA90/TTRGAA9             |
|            | P103/TIAA91/TEVTAA9/TOAA91 | TIAA91/TEVTAA9             |



| Table 2-43 | Input signals with digital filters (2/2) |  |
|------------|------------------------------------------|--|
|            |                                          |  |

| Function | Pin name                       | Inputs with digital filter |
|----------|--------------------------------|----------------------------|
| Timers S | P110/TAPTS00/TEVTS0            | TAPTS00/TEVTS0             |
|          | P111/TAPTS01/TTRGS0            | TAPTS01/TTRGS0             |
|          | P112/TAPTS02                   | TAPTS02                    |
|          | P113/TAPTS10/TEVTS1            | TAPTS10/TEVTS1             |
|          | P114/TAPTS11/TTRGS1            | TAPTS11/TTRGS1             |
|          | P115/TAPTS12                   | TAPTS12                    |
| Timers T | P70/TIT00/TEVTT1/TOT00/TENCT00 | TIT00/TEVTT1/TENCT00       |
|          | P71/TIT01/TTRGT1/TOT01/TENCT01 | TIT01/TTRGT1/TENCT01       |
|          | P72/TECRT0/INTP12              | TECRT0/INTP12              |
|          | P73/TIT10/TTRGT0/TOT10/TENCT11 | TIT10/TTRGT0/TENCT11       |
|          | P74/TIT11/TEVTT0/TOT11/TENCT10 | TIT11/TEVTT0/TENCT10       |
|          | P75/TECRT1/AFO                 | TECRT1                     |

**Filter operation** The input terminal signal is sampled with the sampling frequency f<sub>s</sub>. Spikes shorter than 4 sampling cycles are suppressed and no internal signal is generated. Pulses longer than 5 sampling cycles are recognized as valid pulses and an internal signal is generated. For pulses between 4 and 5 sampling cycles, the behaviour is not defined. The filter operation is illustrated in *Figure 2-3*.



#### Figure 2-3 Digital noise removal example

The minimum input terminal pulse width to be validated is defined by the sampling frequency  $f_s$ . The sampling frequency  $f_s$  can be chosen as 32 MHz or 4 MHz by the noise rejection time control register NCR.

#### Table 2-44 Digital noise removal features

| Sampling frequency fs | Minimum pulse width to generate an internal signal |  |  |  |
|-----------------------|----------------------------------------------------|--|--|--|
| 32 MHz                | 125 – 156.25 ns                                    |  |  |  |
| 4 MHz                 | 1 – 1.25 µsec                                      |  |  |  |

The sampling clock for the noise elimination circuit can be individually adjusted for each of the aforementioned external input signals. The clock is specified by the 8-bit register NRC.

RENESAS

#### (1) NRC - Noise rejection time control register

The 8-bit NRC register specifies the sampling clock for the noise elimination circuit.

Access This register can be read/written in 8-bit and 1-bit units.

Address FFFF F7A0<sub>H</sub>

Initial Value  $00_{\text{H}}$ . This register is cleared by RESET.

| _ | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|---|------|------|------|------|------|------|------|------|
|   | NRC7 | NRC6 | NRC5 | NRC4 | NRC3 | NRC2 | NRC1 | NRC0 |
|   | R/W  |

#### Table 2-45 NRC register contents

| Bit position | Bit name | Function                                                                                                                                                                                                               |
|--------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 to 0       | NRC[7:0] | Sets the sampling clock for the noise elimination<br>circuit for the corresponding input signal:<br>0: 32 MHz<br>1: 4 MHz<br>For an assignment of bit positions to input signals see<br><i>Table 2-46 on page 66</i> . |

#### Table 2-46 Assignment of input signals to bit positions for register NRC

| Bit position | Bit name | Input signals                                                                                                                                      | Description                                                                       |
|--------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|
| 7            | NRC7     | <ul><li>TAPTS10 to TAPTS12, TEVTS1, TTRGS1</li><li>TAPTS00 to TAPTS02, TEVTS0, TTRGS0</li></ul>                                                    | <ul><li>Timer TMS1 input channels</li><li>Timer TMS0 input channels</li></ul>     |
| 6            | NRC6     | <ul><li>TIAA90, TIAA91, TEVTAA9, TTRGAA9</li><li>TIAA80, TIAA81, TEVTAA8, TTRGAA8</li></ul>                                                        | <ul><li>Timer TAA9 input channels</li><li>Timer TAA8 input channels</li></ul>     |
| 5            | NRC5     | <ul><li>TIAA70, TIAA71, TEVTAA7, TTRGAA7</li><li>TIAA60, TIAA61, TEVTAA6, TTRGAA6</li></ul>                                                        | <ul><li>Timer TAA7 input channels</li><li>Timer TAA6 input channels</li></ul>     |
| 4            | NRC4     | <ul><li>TIAA50, TIAA51, TEVTAA5, TTRGAA5</li><li>TIAA40, TIAA41, TEVTAA4, TTRGAA4</li></ul>                                                        | <ul><li>Timer TAA5 input channels</li><li>Timer TAA4 input channels</li></ul>     |
| 3            | NRC3     | <ul><li>TIAA30, TIAA31, TEVTAA3, TTRGAA3</li><li>TIAA20, TIAA21, TEVTAA2, TTRGAA2</li></ul>                                                        | <ul><li>Timer TAA3 input channels</li><li>Timer TAA2 input channels</li></ul>     |
| 2            | NRC2     | <ul><li>TIAA10, TIAA11, TEVTAA1, TTRGAA1</li><li>TIAA00, TIAA01, TEVTAA0, TTRGAA0</li></ul>                                                        | <ul><li>Timer TAA1 input channels</li><li>Timer TAA0 input channels</li></ul>     |
| 1            | NRC1     | <ul> <li>TIT10, TIT11, TEVTT1, TTRGT1, TECRT1,<br/>TENCT11, TENCT10</li> <li>TIT00, TIT01, TEVTT0, TTRGT0, TECRT0,<br/>TENCT01, TENCT00</li> </ul> | <ul><li>Timer TMT1 input channels</li><li>Timer TMT0 input channels</li></ul>     |
| 0            | NRC0     | ADTRG0, ADTRG1     INTP2 to INTP12                                                                                                                 | <ul><li>ADC0 and ADC1 trigger input</li><li>External interrupts 2 to 12</li></ul> |



# 2.5 Pin Functions during and after Reset

The following table summarizes the status of the pins during reset and after reset release in normal operation mode, i.e. MODE1 = 0.

| able 2-47 | Pin functions during and after RESET |  |  |  |  |
|-----------|--------------------------------------|--|--|--|--|
|           |                                      |  |  |  |  |

| Pin name                                                |                  | RESET = 0 | RESET = 1        |                                          |  |
|---------------------------------------------------------|------------------|-----------|------------------|------------------------------------------|--|
|                                                         |                  |           | Normal operation | CPU in HALT<br>mode,<br>DMA<br>operating |  |
| N-Wire interfac                                         | N-Wire interface |           |                  |                                          |  |
| DCK                                                     | DRST = L         | Hi-Z      | Hi-Z             | Hi-Z                                     |  |
|                                                         | DRST = H         | operating | operating        | operating                                |  |
| DDI                                                     | DRST = L         | Hi-Z      | Hi-Z             | Hi-Z                                     |  |
|                                                         | DRST = H         | operating | operating        | operating                                |  |
| DDO                                                     | DRST = L         | Hi-Z      | L                | L                                        |  |
|                                                         | DRST = H         | operating | operating        | operating                                |  |
| DMS                                                     | DRST = L         | Hi-Z      | Hi-Z             | Hi-Z                                     |  |
|                                                         | DRST = H         | operating | operating        | operating                                |  |
| Pins in alternative mode, which are not mentioned above |                  |           |                  |                                          |  |
| Alternative inputs                                      |                  | -         | operating        | operating                                |  |
| Alternative outputs                                     |                  | _         | operating        | operating                                |  |
| Pins in port mode, which are not mentioned above        |                  |           |                  |                                          |  |
| Port inputs                                             |                  | Hi-Z      | operating        | -                                        |  |
| Port outputs                                            |                  | -         | operating        | retains the last<br>status               |  |

# Table 2-47 Pin functions during and after RESET



# 2.6 Recommended Connection of unused Pins

If a pin is not used, it is recommended to connect it as follows:

#### Table 2-48 Recommended connection of unused pins

| Pin                                                                                                                                         | Recommended connection                                                                                                 |  |  |
|---------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|--|--|
| Port pins                                                                                                                                   |                                                                                                                        |  |  |
| Pins of port group 0: P0[4:0]                                                                                                               | connect to VSS3x                                                                                                       |  |  |
| Pins of all other port groups:<br>P1[7:0], P2[7:0], P3[7:0], P4[5:0],<br>P5[7:0], P6[7:0], P7[5:0], P8[6:0],<br>P9[6:0], P10[3:0], P11[5:0] | <ul> <li>output ports:<br/>leave open</li> <li>input ports:<br/>connect to VDD3x or VSS3x via<br/>resistors</li> </ul> |  |  |
| Non-port pins                                                                                                                               |                                                                                                                        |  |  |
| ANI00 to ANI09                                                                                                                              | connect to AVDD or AVSS0                                                                                               |  |  |
| ANI10 to ANI19                                                                                                                              | connect to AVDD or AVSS1                                                                                               |  |  |
| DCK, DDI, DMS                                                                                                                               | connect to VDD3x via resistors                                                                                         |  |  |
| DDO                                                                                                                                         | leave open                                                                                                             |  |  |
| DRST                                                                                                                                        | connect to VSS3x                                                                                                       |  |  |

**Caution** Pins to be connected via a resistor to VSS3x respectively VDD3x must be connected via separate resistors.

- Note 1. For pins requiring a pull-up/-down resistor a resistance of 1 to 10 K $\Omega$ . is recommended.
  - 2. If the overall maximum output current exceeds its maximum value the output buffer can be damaged. We recommend the placement of a series resistor to prevent damage in case of accidentally enabled outputs. Refer to the absolute maximum rating parameter in the Data Sheet.



# 2.7 Package Pins Assignment

The following figure shows the pin location of a packaged device. Every pin is labelled with its pin name. This diagram is a schematic top view only, for detailed package drawing please regard the electrical specification document.

Note When connecting the pins, consider the following:

- VDD15 / VSS15: 1.5V supply (for details please regard the electrical specification document)
- CVDD / CVSS: 1.5V supply (for details please regard the electrical specification document)
- VDD30 / VSS30: 3.3V supply (for details please regard the electrical specification document)
- AVDD / AVSS: 3.3V supply (for details please regard the electrical specification document)
- AVSS: Avoid injecting noise from VSS30 or VSS15 by providing a low impedance connection of AVSS to a location with low noise ground potential.





Figure 2-4 Pin overview



# **Chapter 3 CPU System Functions**

This chapter describes the registers of the CPU, the operation modes, the address space and the memory areas.

# 3.1 Overview

The CPU is founded on Harvard architecture and it supports a RISC instruction set. Basic instructions can be executed in one clock period. Optimized five-stage pipelining is supported. This improves instruction execution speed.

The floating-point unit (FPU) supports online diagnostics as well as applications demanding floating-point representation such as physical sensor data or automatically generated code.

In order to make the microcontroller ideal for use in digital control applications, a 32-bit hardware multiplier enables this CPU to support multiply instructions, saturated multiply instructions, bit operation instructions, etc.

Features summary The CPU has the following special features:

#### • Memory space:

- 64 MB linear program space
- 4 GB linear data space
- 32 general purpose registers
- Internal 32-bit architecture
- Five-stage pipeline
- Efficient multiplication and division instructions
- Saturation logic (saturated operation instructions)
- Floating-point arithmetic unit (single precision, 32 bits, according to IEEE 754-85 standard)
- Barrel shifter (32-bit shift in one clock cycle)
- · Instruction formats: long and short
- · Four types of bit manipulation instructions: set, clear, not, test



# 3.1.1 Description

The figure below shows a block diagram of the microcontroller, focusing on the CPU and modules that interact with the CPU directly. *Table 3-1* lists the bus types.



Figure 3-1 CPU system

The shaded busses are used for accessing the configuration registers of the concerned modules.

#### Table 3-1 Bus types

| Bus type             | Function                                                                                            |  |  |
|----------------------|-----------------------------------------------------------------------------------------------------|--|--|
| NPB – Peripheral bus | Bus interface to the peripherals (internal bus).                                                    |  |  |
| VSB – System bus     | Bus interface to the Memory Controller for access to external memory and to the NPB bus bridge BBR. |  |  |
| VFB – Fetch bus      | Interface to the internal ROM (mask ROM or flash ROM).                                              |  |  |
| VDB – Data bus       | Interface to the internal RAM.                                                                      |  |  |



n

### 3.2 CPU Register Set

There are three categories of registers:

- · General purpose registers
- · System registers
- · Floating-point arithmetic registers

All registers are 32-bit registers. An overview is given in the figure below. For details, refer to V850E1 User's Manual Architecture.

| General purpose registers   | Syster  | m registers                                          |
|-----------------------------|---------|------------------------------------------------------|
| 1                           | 0 31    |                                                      |
| r0 (Zero Register)          | EIPC    | (Status Saving Register during interrupt)            |
| 1 (Reserved for Assembler)  | EIPSW   | (Status Saving Register during interrupt)            |
| 2                           |         |                                                      |
| 3 (Stack Pointer (SP))      | FEPC    | (Status Saving Register during NMI)                  |
| 4 (Global Pointer (GP))     | FEPSW   | (Status Saving Register during NMI)                  |
| (Text Pointer (TP))         |         |                                                      |
| 6                           | ECR     | (Interrupt/Execution Source Register)                |
| 7                           |         | (interrup), zvecution bource negister,               |
| 8                           | PSW     | (Program Status Word)                                |
| 9                           |         |                                                      |
| -10                         | СТРС    | (Status Saving Register during CALLT execution       |
| r1 1                        | CTPC    |                                                      |
| 2                           | CIPSW   | (Status Saving Register during CALLI execution       |
| 3                           |         |                                                      |
| 4                           | DBPC    | (Status Saving Register during exception/debug trap) |
| 5                           | DBPSW   | (Status Saving Register during exception/debug trap) |
| 6                           |         |                                                      |
| 7                           | СТВР    | (CALLT Base Pointer)                                 |
| 8                           |         |                                                      |
| 19                          | PC      | (Program Counter)                                    |
| 20                          |         |                                                      |
| 2 1                         |         |                                                      |
| 22                          |         |                                                      |
| 12 3                        |         |                                                      |
| r2 4                        |         |                                                      |
| r2 5                        |         |                                                      |
| r2 6                        |         |                                                      |
| r2 7                        |         |                                                      |
| r2 8                        | Floatin | ng point arithmetic registers                        |
| r2 9                        |         |                                                      |
| r3 0 (Element Pointer (EP)) | EFG     | (Floating-point arithmetic flag register)            |
| r3 1 (Link Pointer (LP))    | ECT     | (Floating-point arithmetic control register)         |

Figure 3-2 CPU register set

Some registers are write protected. That means, writing to those registers is protected by a special sequence of instructions. Refer to "Write Protected Registers" on page 97 for more details.



### 3.2.1 General purpose registers (r0 to r31)

Each of the 32 general purpose registers can be used as a data variable or address variable.

However, the registers r0, r1, r3 to r5, r30, and r31 may implicitly be used by the assembler/compiler (see *Table 3-2*). For details refer to the documentation of your assembler/compiler.

### Table 3-2 General purpose registers

| Register name | Usage                          | Operation                                                                                                                                 |
|---------------|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| rO            | Zero register                  | Always holds 0. It is used for operations using 0 and offset 0 addressing. <sup>a</sup>                                                   |
| r1            | Assembler-reserved register    | Used for 32-bit direct addressing. <sup>b</sup>                                                                                           |
| r2            | User address/data variable reg | gister                                                                                                                                    |
| r3            | Stack pointer                  | Used to generate stack frame when function is called. <sup>b</sup>                                                                        |
| r4            | Global pointer                 | Used to access global variable in data area. <sup>b</sup>                                                                                 |
| r5            | Text pointer                   | Used to indicate the start of the text area (where program code is located). <sup>b</sup>                                                 |
| r6 to r29     | User address/data variable reg | gisters                                                                                                                                   |
| r30           | Element pointer                | Base pointer when memory is<br>accessed by means of instructions<br>SLD (short format load) and SST<br>(short format store). <sup>a</sup> |
| r31           | Link pointer                   | Used when calling a function. <sup>b</sup>                                                                                                |

a) Registers r0 and r30 are used by dedicated instructions.

<sup>b)</sup> Registers r1, r3, r4, r5, and r31 may be used by the assembler/compiler.

**Caution** Before using registers r1, r3 to r5, r30, and r31, their contents must be saved so that they are not lost. The contents must be restored to the registers after the registers have been used.



### 3.2.2 System register set

System registers control the status of the CPU and hold interrupt information. Additionally, the program counter holds the instruction address during program execution.

To read/write the system registers, use instructions LDSR (load to system register) or STSR (store contents of system register), respectively, with a specific system register number (RegID) indicated below. The program counter states an exception. It cannot be accessed via LDSR or STSR instructions. No regID is allocated to the program counter.

Example STSR 0, r2

Stores the contents of system register 0 (EIPC) in general purpose register r2.

System register numbers The table below gives an overview of all system registers and their system register number (regID). It shows whether a load/store instruction is allowed (×) for the register or not (–).

| realD    | System register nome                                                           | Shortcut | Operand specification |      |  |
|----------|--------------------------------------------------------------------------------|----------|-----------------------|------|--|
| regID    | System register name                                                           | Shoricul | LDSR                  | STSR |  |
| 0        | Status saving register during interrupt (stores contents of PC)                | EIPC     | ×                     | ×    |  |
| 1        | Status saving register during interrupt (stores contents of PSW)               | EIPSW    | ×                     | ×    |  |
| 2        | Status saving register during non-maskable interrupts (stores contents of PC)  | FEPC     | ×                     | ×    |  |
| 3        | Status saving register during non-maskable interrupts (stores contents of PSW) | FEPSW    | ×                     | ×    |  |
| 4        | Interrupt source register                                                      | ECR      | -                     | ×    |  |
| 5        | Program status word                                                            | PSW      | ×                     | ×    |  |
| 6 to 15  | Reserved (operations that access these register numbers cannot be guaranteed). |          | -                     | _    |  |
| 16       | Status saving register during CALLT execution (stores contents of PC)          | CTPC     | ×                     | ×    |  |
| 17       | Status saving register during CALLT execution (stores contents of PSW)         | CTPSW    | ×                     | ×    |  |
| 18       | Status saving register during exception/debug trap (stores contents of PC)     | DBPC     | × <sup>a</sup>        | ×    |  |
| 19       | Status saving register during exception/debug trap (stores contents of PSW)    | DBPSW    | × <sup>a</sup>        | ×    |  |
| 20       | CALLT base pointer                                                             | CTBP     | ×                     | ×    |  |
| 21 to 31 | Reserved (operations that access these register numbers cannot be guaranteed). |          | -                     | _    |  |

#### Table 3-3 System register numbers

a) Reading from this register is only enabled between a DBTRAP exception (exception handler address 0000 0060<sub>H</sub>) and the exception handler terminating DBRET instruction. DBTRAP exceptions are generated upon ILGOP detections (refer to *"Interrupt Controller (INTC)" on page 99*).



#### (1) PC - Program counter

The program counter holds the instruction address during program execution. The lower 26 bits are valid, and bits 31 to 26 are fixed to 0. If a carry occurs from bit 25 to 26, it is ignored. Branching to an odd address cannot be performed. Bit 0 is fixed to 0.

Access This register can not be accessed by any instruction.

Initial Value 0000 0000<sub>H</sub>. The program counter is cleared by RESET.

| 31 |            | 26 | 25 |                                      | 1 | 0 |
|----|------------|----|----|--------------------------------------|---|---|
|    | fixed to 0 |    |    | instruction address during execution |   | 0 |

### (2) EIPC, FEPC, DBPC, CTPC - PC saving registers

The PC saving registers save the contents of the program counter for different occasions, see *Table 3-4*.

When one of the occasions listed in *Table 3-4* occurs, except for some instructions, the address of the instruction following the one being executed is saved to the saving registers.

For more details refer to *Table 3-9 on page 80* and to the *"Interrupt Controller (INTC)" on page 99*.

All PC saving registers are built up as the PC, with the initial value  $0xxx xxx_H$  (x = undefined).

#### Table 3-4 PC saving registers

| Register                                                    | Shortcut          | Saves contents of PC in case of                                                                                     |
|-------------------------------------------------------------|-------------------|---------------------------------------------------------------------------------------------------------------------|
| Status saving register<br>during interrupt                  | EIPC              | <ul><li>software exception</li><li>maskable interrupt</li></ul>                                                     |
| Status saving register<br>during non-maskable<br>interrupts | FEPC              | non-maskable interrupt                                                                                              |
| Status saving register<br>during exception/debug<br>trap    | DBPC <sup>a</sup> | <ul> <li>exception trap</li> <li>debug trap</li> <li>debug break</li> <li>during a single-step operation</li> </ul> |
| Status saving register<br>during CALLT execution            | CTPC              | execution of CALLT instruction                                                                                      |

<sup>a)</sup> Reading from this register is only enabled in debug mode. Otherwise, the read value is undefined.

**Note** When multiple interrupt servicing is enabled, the contents of EIPC or FEPC must be saved by program because only one PC saving register for maskable interrupts and non-maskable interrupts is provided, respectively.

**Caution** When setting the value of any of the PC saving registers, use even values (bit 0 = 0). If bit 0 is set to 1, the setting of this bit is ignored. This is because bit 0 of the program counter is fixed to 0.

RENESAS

### (3) PSW - Program status word

The 32-bit program status word is a collection of flags that indicates the status of the program (result of instruction execution) and the status of the CPU.

If the bits in the register are modified by the LDSR instruction, the PSW will take on the new value immediately after the LDSR instruction has been executed.

Initial Value 0000 0020<sub>H</sub>. The program status is initialized by RESET.

| 31         | 8 | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------------|---|-----|-----|-----|-----|-----|-----|-----|-----|
| fixed to 0 |   | NP  | EP  | ID  | SAT | CY  | OV  | S   | Z   |
| R          | R | R/W |

| Table 3-5 | PSW register of | contents (1/2) |
|-----------|-----------------|----------------|
|-----------|-----------------|----------------|

| Bit position | Flag             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|--------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 7            | NP               | <ul> <li>Indicates that non-maskable interrupt (NMI) servicing is in progress.</li> <li>This flag is set when NMI request is acknowledged, and multiple interrupt servicing is disabled.</li> <li>0: NMI servicing is not in progress.</li> <li>1: NMI servicing is in progress.</li> </ul>                                                                                                                                                                                                                                  |  |  |  |
| 6            | EP               | <ul> <li>Indicates that exception processing is in progress.</li> <li>This flag is set when an exception occurs. Even when this bit is set, interrupt requests can be acknowledged.</li> <li>0: Exception processing is not in progress.</li> <li>1: Exception processing is in progress.</li> </ul>                                                                                                                                                                                                                         |  |  |  |
| 5            | ID               | <ul> <li>Indicates whether a maskable interrupt request can be acknowledged.</li> <li>0: Interrupts enabled.</li> <li>1: Interrupts disabled.</li> <li>Note: Setting this flag will disable interrupt requests even while the LDSR instruction is being executed.</li> </ul>                                                                                                                                                                                                                                                 |  |  |  |
| 4            | SAT <sup>a</sup> | <ul> <li>For saturated operation processing instructions only:<br/>Indicates that the operation result is saturated due to overflow.</li> <li>0: Not saturated.</li> <li>1: Saturated.</li> <li>Note: 1. This is a cumulative flag: The bit is not automatically cleared if<br/>subsequent instructions lead to not saturated results.<br/>To clear this bit, use the LDSR instruction to set PSW.SAT = 0.</li> <li>2. In a general arithmetic operation this bit is neglected. It is neithe<br/>set nor cleared.</li> </ul> |  |  |  |
| 3            | CY               | Carry/borrow flag.<br>Indicates whether a carry or borrow occurred as a result of the operation.<br>0: Carry or borrow did not occur<br>1: Carry or borrow occurred.                                                                                                                                                                                                                                                                                                                                                         |  |  |  |



| Bit position | Flag            | Function                                                                                                                                      |
|--------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 2            | OV <sup>a</sup> | Overflow flag.<br>Indicates whether an overflow occurred as a result of the operation.<br>0: Overflow did not occur.<br>1: Overflow occurred. |
| 1            | S <sup>a</sup>  | Sign flag.<br>Indicates whether the result of the operation is negative.<br>0: Result is positive or zero.<br>1: Result is negative.          |
| 0            | Z               | Zero flag.<br>Indicates whether the result of the operation is zero.<br>0: Result is not zero.<br>1: Result is zero.                          |

### Table 3-5 PSW register contents (2/2)

a) In the case of saturate instructions, the SAT, S, and OV flags will be set according to the result of the operation as shown in the table below. Note that the SAT flag is set only when the OV flag has been set during a saturated operation.

# Saturated operation<br/>instructionsThe following table shows the setting of flags PWS.SAT, PWS.OV, and PWS.S,<br/>depending on the status of the operation result.

### Table 3-6 Saturation-processed operation result

| Status of operation result      | Flag status |    |   | Saturation-processed    |  |
|---------------------------------|-------------|----|---|-------------------------|--|
|                                 |             | ov | S | operation result        |  |
| Maximum positive value exceeded | 1           | 1  | 0 | 7FFF FFFF <sub>H</sub>  |  |
| Maximum negative value exceeded | 1           | 1  | 1 | 8000 0000 <sub>H</sub>  |  |
| Positive (maximum not exceeded) |             | 0  | 0 | Operation result itself |  |
| Negative (maximum not exceeded) |             | 0  | 1 |                         |  |

a) Retains the value before operation.



### (4) EIPSW, FEPSW, DBPSW, CTPSW saving registers

The PSW saving registers save the contents of the program status word for different occasions, see Table 3-4.

When one of the occasions listed in Table 3-4 occurs, the current value of the PSW is saved to the saving registers.

All PSW saving registers are built up as the PSW, with the initial value  $0000 0xxx_H (x = undefined).$ 

### Table 3-7 PSW saving registers

| Register                                                    | Shortcut           | Saves contents of PSW in case of                                                                                    |
|-------------------------------------------------------------|--------------------|---------------------------------------------------------------------------------------------------------------------|
| Status saving register<br>during interrupt                  | EIPSW              | <ul><li>software exception</li><li>maskable interrupt</li></ul>                                                     |
| Status saving register<br>during non-maskable<br>interrupts | FEPSW              | non-maskable interrupt                                                                                              |
| Status saving register<br>during exception/debug<br>trap    | DBPSW <sup>a</sup> | <ul> <li>exception trap</li> <li>debug trap</li> <li>debug break</li> <li>during a single-step operation</li> </ul> |
| Status saving register during CALLT execution               | CTPSW              | execution of CALLT instruction                                                                                      |

a) Reading from this register is only enabled in debug mode. Otherwise, the read value is undefined.

- Note When multiple interrupt servicing is enabled, the contents of EIPSW or FEPSW must be saved by program because only one PSW saving register for maskable interrupts and non-maskable interrupts is provided, respectively.

Caution Bits 31 to 26 of EIPC and bits 31 to 12 and 10 to 8 of EIPSW are reserved for future function expansion (fixed to 0). When setting the value of EIPC, FEPC, or CTPC, use even values (bit 0 = 0).

If bit 0 is set to 1, the setting of this bit is ignored. This is because bit 0 of the program counter is fixed to 0.



#### (5) ECR - Interrupt/exception source register

The 32-bit ECR register displays the exception codes if an exception or an interrupt has occurred. With the exception code, the interrupt/exception source can be identified.

For a list of interrupts/exceptions and corresponding exception codes, see *Table 3-9 on page 80*.

**Initial Value** 0000 0000<sub>H</sub>. This register is cleared by  $\overline{\text{RESET}}$ .

| 31 | 26   | 26 25 |  |  |
|----|------|-------|--|--|
|    | FECC | EICC  |  |  |

#### Table 3-8 ECR register contents

| Bit<br>position | Bit name | Function                                           |
|-----------------|----------|----------------------------------------------------|
| 31 to 16        | FECC     | Exception code of non-maskable interrupt (NMI)     |
| 15 to 0         | EICC     | Exception code of exception or maskable interrupts |

The following table lists the exception codes.

| Table 3-9 Ir | nterrupt/execution codes | 5 |
|--------------|--------------------------|---|
|--------------|--------------------------|---|

| Interrupt/Exc      | eption Source                        |                                        |                | Exception                                                     | Handler                                                                                             | Value                    |
|--------------------|--------------------------------------|----------------------------------------|----------------|---------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|--------------------------|
| Name               |                                      | Trigger                                | Classification | Code                                                          | Address                                                                                             | restored to<br>EIPC/FEPC |
| Non-maskable       | e interrupt (NMI)                    | refer to<br><i>"Interrupt</i>          | Interrupt      | 0010 <sub>H</sub>                                             | 0000 0010 <sub>H</sub>                                                                              | next PC<br>(see Note)    |
| Maskable inte      | rrupt                                | Controller<br>(INTC)"<br>on<br>page 99 | Interrupt      | refer to<br>"Interrupt<br>Controller<br>(INTC)" on<br>page 99 | <ul> <li>higher 16 bits:<br/>0000<sub>H</sub></li> <li>lower 16 bits:<br/>exception code</li> </ul> | next PC<br>(see Note)    |
| Software exception | TRAP0n<br>(n = 0 to F <sub>H</sub> ) | TRAP<br>instruction                    | Exception      | 004n <sub>H</sub>                                             | 0000 0040 <sub>H</sub>                                                                              | next PC                  |
|                    | TRAP1n<br>(n = 0 to F <sub>H</sub> ) | TRAP<br>instruction                    | Exception      | 005n <sub>H</sub>                                             | 0000 0050 <sub>H</sub>                                                                              | next PC                  |
| Exception trap     | (ILGOP)                              | Illegal<br>instruction<br>code         | Exception      | 0060 <sub>H</sub>                                             | 0000 0060 <sub>H</sub>                                                                              | next PC                  |
| Debug trap         |                                      | DBTRAP<br>instruction                  | Exception      | 0060 <sub>H</sub>                                             | 0000 0060 <sub>H</sub>                                                                              | next PC                  |

If an interrupt (maskable or non-maskable) is acknowledged during instruction execution, generally, the address of the instruction *following* the one being executed is saved to the saving registers, except when an interrupt is acknowledged during execution of one of the following instructions:

- load instructions (SLD.B, SLD.BU, SLD.H, SLD.HU, SLD.W)
- divide instructions (DIV, DIVH, DIVU, DIVHU)
- PREPARE, DISPOSE instruction (only if an interrupt is generated before the stack pointer is updated)

In this case, the address of the *interrupted* instruction is restored to the EIPC or FEPC, respectively. Execution is stopped, and after the completion of interrupt servicing the execution is resumed.

RENESAS

### (6) CTBP - CALLT base pointer

The 32-bit CALLT base pointer is used with the CALLT instruction. The register content is used as a base address to generate both a 32-bit table entry address and a 32-bit target address.

Initial Value Undefined

| 31             | 30             | 29             | 28             | 27             | 26             | 25           | 1 | 0 |
|----------------|----------------|----------------|----------------|----------------|----------------|--------------|---|---|
| 0              | 0              | 0              | 0              | 0              | 0              | base address |   | 0 |
| R <sup>a</sup> | R/W          |   | R |

<sup>a)</sup> These bits may be written, but write is ignored.



### 3.2.3 Floating-point arithmetic registers

Floating-point arithmetic unit (FPU) is controlled by means of the following registers:

### Table 3-10 FPU control registers

| Register name                              | Shortcut |
|--------------------------------------------|----------|
| Floating-point arithmetic flag register    | EFG      |
| Floating-point arithmetic control register | ECT      |

### (1) EFG - Floating-point arithmetic flag register

The 32-bit EFG register holds the status of the FPU.

Initial Value 0000 0000<sub>H</sub>.

| 31 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7 | 6 | 5 | 4  | 3 | 2  | 1 | 0 |
|----|----|----|----|----|----|----|----|---|---|---|----|---|----|---|---|
| (  | )  | RO | IV | ZD | VF | UD | PR | 0 | 0 | 0 | TR | 0 | OV | S | Z |

### Table 3-11EFG register contents (1/2)

| Bit<br>position                                                                                                                             | Bit name | Function                                                                                                                                                                                                                                                             |
|---------------------------------------------------------------------------------------------------------------------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13                                                                                                                                          | RO       | Running Operation: Indicates whether the floating-point arithmetic unit is running.<br>0: Operation in progress.<br>1: FPU idle.                                                                                                                                     |
| 12                                                                                                                                          | IV       | InValid operation: Indicates that an invalid operation has been requested.<br>0: Normal operation.<br>1: Invalid operation detected.                                                                                                                                 |
| 11                                                                                                                                          | ZD       | <ul><li>Zero Divide: Indicates whether a division by 0 has been detected.</li><li>0: Normal operation.</li><li>1: Division by 0 detected.</li></ul>                                                                                                                  |
| 10                                                                                                                                          | VF       | oVerFlow: Indicates that the result of executing a floating-point operation has<br>overflowed.<br>0: No overflow generated.<br>1: Overflow generated.                                                                                                                |
| 9                                                                                                                                           | UD       | UnDervalue: Indicates that the result of executing a floating-point operation has<br>underflowed.<br>0: No underflow generated.<br>1: Underflow generated.                                                                                                           |
| 8                                                                                                                                           | PR       | PRecision error: indicates that an accuracy failure occurred.<br>0: No accuracy failure occurred.<br>1: Accuracy failure occurred.                                                                                                                                   |
| 4                                                                                                                                           | TR       | <ul> <li>This flag summarizes the state of the FPU:</li> <li>0: Normal state.</li> <li>1: Abnormal condition detected: one of the bits 12 to 8 of the ECT register is set.</li> <li>The setting conditions of this flag depend on the ECT register value.</li> </ul> |
| 2 OV<br>OVerflow: Indicates whether an overflow occurred during floati<br>conversion<br>0: No overflow generated.<br>1: Overflow generated. |          | 0: No overflow generated.                                                                                                                                                                                                                                            |
| 1                                                                                                                                           | S        | <ul> <li>Sign: Indicates whether a floating-point operation result is negative.</li> <li>0: Operation result is not negative.</li> <li>1: Operation result is negative.</li> </ul>                                                                                   |



| Bit<br>position | Bit name | Function                                                                                                                                                  |
|-----------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0               | Z        | <ul><li>Zero: Indicates whether a floating-point operation result is 0.</li><li>0: Operation result is not 0.</li><li>1: Operation result is 0.</li></ul> |

### Table 3-11 EFG register contents (2/2)

### (2) ECT - Floating-point arithmetic control register

The 32-bit ECT register controls the setting conditions of the TR flag in the EFG register. The TR flag is a logical OR between all the invalid operations the FPU can detect. Each bit of ECT is a mask bit for one condition.

Initial Value 0000 0000<sub>H</sub>.

| 31 | 13 | 12 | 11 | 10 | 9  | 8  | 7 |   | 0 |
|----|----|----|----|----|----|----|---|---|---|
| 0  |    | IT | ZT | VT | UT | PT |   | 0 |   |

### Table 3-12 ECT register contents

| Bit<br>position | Bit name | Function                                                                                                                                                                                              |  |  |
|-----------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 12              | IT       | Enables invalid operation detection in the TR value calculation<br>0: IV is set when an invalid operation is detected<br>1: IV and TR are set when an invalid operation is detected                   |  |  |
| 11              | ZT       | Enables zero divide operation detection in the TR value calculation<br>0: ZD is set when a zero divide operation is detected.<br>1: ZD and TR are set when a zero divide operation is detected.       |  |  |
| 10              | VT       | Enables overflow detection in the TR value calculation<br>0: VF is set when an overflow is detected.<br>1: VF and TR are set when an overflow is detected.                                            |  |  |
| 9               | UT       | Enables underflow detection in the TR value calculation<br>0: UD is set when an underflow is detected.<br>1: UD and TR are set when an underflow is detected.                                         |  |  |
| 8               | PT       | <ul><li>Enables accuracy fail detection in the TR value calculation</li><li>0: PR is set when an accuracy fail is detected.</li><li>1: PR and TR are set when an accuracy fail is detected.</li></ul> |  |  |



### 3.3 Operation Modes

This section describes the operation modes of the CPU and how the modes are specified.

The following operation modes are available for the flash memory devices:

- Normal operation mode
- Flash programming mode

After reset release, the microcontroller starts to fetch instructions from an internal boot ROM which contains the internal firmware. The firmware checks the pins MODE0 to MODE3 to set the operation mode after reset release according to *Table 3-13*.

#### Table 3-13 Selection of operation modes

|       | Pi    | ns              |                 |                                             |  |
|-------|-------|-----------------|-----------------|---------------------------------------------|--|
| MODE3 | MODE2 | MODE1/<br>FLMD0 | MODE0/<br>FLMD1 | Operation Mode                              |  |
|       | 0 0   |                 |                 | Normal operation mode<br>(fetch from flash) |  |
| 0     |       | 1               | 0               | Flash programming mode                      |  |
|       | all o | other           | Reserved        |                                             |  |

Note 1. The MODE1 pin function is shared with the FLMD0 pin.

2. Pins MODE0 and MODE3 must be connected to VSS3x.

### 3.3.1 Normal operation mode

In normal operation mode, the internal flash memory is not re-programmed.

After reset release program execution is started at address 0000 0000<sub>H</sub>.

The lower 1 MB of the memory area is mapped to internal resources, for instance to the internal flash memory.

### 3.3.2 Flash programming mode

In flash programming mode, the internal flash memory is erased and re-programmed.

After reset release, the firmware initiates loading of the user's program code from the external flash programmer and programs the flash memory.

After detaching the external flash programmer, the microcontroller can be started up with the new user's program in normal operation mode.

For more information see section "Flash Memory" on page 159.



### 3.4 Address Space

In the following sections, the address space of the CPU is explained. Size and addresses of CPU address space and physical address space are explained. The address range of data space and program space together with their wraparound properties are presented.

### 3.4.1 CPU address space and physical address space

The CPU supports the following address space:

- 4 GB CPU address space With the 32-bit general purpose registers, addresses for a 4 GB memory can be generated. This is the maximum address space supported by the CPU.
- 256 MB physical address space The CPU provides 256 MB physical address space. That means that a maximum of 256 MB internal or external memory can be accessed.

Any 32-bit address is translated to its corresponding physical address by ignoring bits 31 to 28 of the address. Thus, 16 addresses point to the same physical memory address. In other words, data at the physical address  $0000\ 0000_H$  can additionally be accessed by addresses  $1000\ 0000_H$ , 2000  $0000_H$ , ..., E000  $0000_H$ , or F000  $0000_H$ .

The 256 MB physical address space is seen as 16 images in the 4 GB CPU address space as shown in *Figure 3-3*.





Figure 3-3 Images in the CPU address space

- **Note** 1. The internal RAM area  $(03FF 7000_H \text{ to } 03FF EFFF_H)$  is mirrored to the area  $0FFF 7000_H$  to  $0FFF EFFF_H$ . If data is written in one area, it appears also in the other area.
  - 2. The programmable peripheral base address is defined by the BPC register.
  - 3.

µPD70F3485: 480 KB up to 0007 7FFF<sub>H</sub>

RENESAS

### 3.4.2 Program and data space

The CPU allows the following assignment of data and instructions to the CPU address space:

- 4 GB as data space The entire CPU address space can be used for operand addresses.
- 64 MB as program space Only the lower 64 MB of the CPU address space can be used for instruction addresses. When an instruction address for a branch instruction is calculated and moved to the program counter (PC), then bits 31 to 26 are set to zero.

*Figure 3-4* shows the assignment of the CPU address space to data and program space.



Figure 3-4 CPU address space



#### (1) Wrap-around of data space

If an operand address calculation exceeds 32 bits, only the lower 32 bits of the result are considered. Therefore, the addresses  $0000\ 0000_H$  and FFFF FFFF<sub>H</sub> are contiguous addresses. This results in a wrap-around of the data space:



Figure 3-5 Wrap-around of data space

#### (2) Wrap-around of program space

If an instruction address calculation exceeds 26 bits, only the lower 26 bits of the result are considered. Therefore, the addresses  $0000\ 0000_H$  and  $03FF\ FFFF_H$  are contiguous addresses. This results in a wrap-around of the program space:



#### Figure 3-6 Wrap-around of program space

**Caution** No instruction can be fetched from the 4 KB area of  $0FFF F000_H$  to  $0FFF FFFF_H$  because this area is defined as peripheral I/O area. Therefore, do not execute any branch to this area.



### 3.5 Memory

In the following sections, the memory of the CPU is introduced. Specific memory areas are described and a recommendation for the usage of the address space is given.

### 3.5.1 Memory areas

The internal memory of the CPU provides several areas:

- Internal flash area for flash memory devices
- Internal RAM area
- Internal fixed peripheral I/O area
- Programmable peripheral I/O area

The areas are briefly described below.

### (1) Internal flash area

summarizes the size and addresses of the internal flash memories. These cannot be used for access to external memory.

#### Table 3-14 Internal flash areas

| Device     | Internal flash size | Address range                                    |  |  |  |  |
|------------|---------------------|--------------------------------------------------|--|--|--|--|
| µPD70F3485 | 480 KB              | 0000 0000 <sub>H</sub> to 0007 7FFF <sub>H</sub> |  |  |  |  |

### (2) Internal RAM area

The 32 KB area between addresses 03FF  $7000_{\rm H}$  and 03FF  $\rm EFFF_{\rm H}$  is provided as the internal RAM area.

**Note** The internal RAM area is mirrored to the area  $0FFF 7000_{H}$  to  $0FFF EFFF_{H}$ . If data is written in one area, it appears also in the other area.

### (3) Fixed peripheral I/O area

The 4 KB area between addresses 0FFF  $F000_H$  and 0FFF  $FFFF_H$  is provided as the fixed peripheral I/O area. Accesses to these addresses are passed over to the NPB bus (internal bus).

The following registers are mapped to the peripheral I/O area:

- All registers of peripheral functions
- Registers of timers
- Configuration registers of Interrupt, DMA, Bus and Memory Controller Units
- Configuration registers of the Clock Generator

For a list of all peripheral I/O registers, see "Special Function Registers" on page 1049.



| Note    | 1.         | Because the physical address space covers 256 MB, the address bits A[31:28] are not considered. Thus, this address space can also be addressed via the area FFFF $F000_H$ to FFFF FFFF <sub>H</sub> . This has the advantage that the area can be indirectly addressed by an offset and the zero base r0.<br>Therefore, in this manual, all addresses of peripheral I/O registers in the 4 KB peripheral I/O area are given in the range FFFF $F000_H$ to FFFF FFFF <sub>H</sub> . |
|---------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | 2.         | The <i>fixed</i> peripheral I/O area is mirrored to the upper 4 KB of the <i>programmable</i> peripheral I/O area PPA—regardless of the base address of the PPA. If data is written to one area, it appears also in the other area.                                                                                                                                                                                                                                                |
|         | 3.         | Program fetches cannot be executed from any peripheral I/O area.                                                                                                                                                                                                                                                                                                                                                                                                                   |
|         | 4.         | Word registers, that means 32-bit registers, are accessed in two half word accesses. The lower two address bits are ignored.                                                                                                                                                                                                                                                                                                                                                       |
|         | 5.         | <ul> <li>For registers in which byte access is possible, if half word access is executed:</li> <li>During read operation: The higher 8 bits become undefined.</li> <li>During write operation: The lower 8 bits of data are written to the register.</li> </ul>                                                                                                                                                                                                                    |
| Caution | (          | Addresses that are not defined as registers are reserved for future<br>expansion. If these addresses are accessed, the operation is undefined and<br>not guaranteed.                                                                                                                                                                                                                                                                                                               |
|         | (<br> <br> | For DMA transfer, the fixed peripheral I/O area (0FFF F000H to<br>DFFF FFFFH) cannot be specified as the source/destination address in the<br>MARn - DMA transfer memory start address registers. Be sure to use the<br>RAM area (0FFF 7000H to 0FFF EFFFH or 03FF 7000H to 03FF EFFFH)<br>for this source/destination address of DMA transfer.                                                                                                                                    |

### (4) Programmable peripheral I/O area

A 16 KB area is provided as a programmable peripheral I/O area (PPA). The PPA can be freely located. The base address of the programmable peripheral I/O area is specified by the initialization of the peripheral area selection control register (BPC).

See "Bus and Memory Control (BCU, MEMC)" on page 192 for details.



### 3.6 RAM ECC error detection

The RAM control circuit is equipped with an error detection function. A 5-bit ECC (Error Correction Coding) code is dedicated to each 8-bit word in the RAM.

The ECC can detect and correct single bit errors and detect double bit errors. In the latter case the double error detection interrupt INTDEDR is generated.

INTDEDR can generate two kinds of interrupts:

- an NMI via the NMI sharing function
- a maskable interrupt (exception code 0080<sub>H</sub>), that is shared with double error detections of the flash memory

Besides generating an non-maskable or maskable interrupt, the address of the erroneous data and the location of the erroneous data byte of the 32-bit data are saved in registers.

Note A RAM access is always performed with 32-bit, i.e. 4-byte, data. Thus a double error detection interrupt INTDEDR is also generated upon an 1-byte or 2-byte access, even if the read target byte(s) are not erroneous, but any other data byte that is read concurrently.

### 3.6.1 RAM ECC initialization

The RAM content and the 5-bit ECC values are undefined after device power-up, the 5-bit ECC values do not fit to their respective 8-bit data. Thus the entire RAM must be initialized, i.e. written, in order to fit the ECC values to the data. Since a double error detection interrupt INTDEDR may have been issued due to undefined data and ECC values after power-up, follow below procedure to start up the RAM ECC:

- 1. After device power-up NMI sharing is disabled (INTSEL.ISR = 0) and the maskable interrupt is masked (ERRIC.ERRMK = 1). Don't enable NMI sharing respectively unmask the maskable interrupt before the RAM has been completely initialized.
- 2. Initialize the entire RAM by writing to all RAM locations. The data written is not of concern.
- 3. Enable NMI sharing by INTSEL.ISR = 1 or unmask the maskable interrupt by ERRIC.ERRMK = 0, whatever is desired.

Also when program code shall be executed from RAM, it is recommended to fill the entire RAM, preferably all data bytes with the NOP instruction code, before fetching the first instruction from RAM. This avoids ECC errors generated by instruction prefetches by the execution pipeline.



### 3.6.2 RAM ECC registers

The RAM ECC is operated by means of the following registers:

#### Table 3-15 RAM ECC registers overview

| Register name                        | Shortcut | Address                |
|--------------------------------------|----------|------------------------|
| RAM ECC error address register       | RAMEAD   | FFFF F8B0 <sub>H</sub> |
| RAM ECC error data location register | RAMEDLR  | FFFF F8B2 <sub>H</sub> |
| RAM ECC control register             | RAMECC   | FFFF F8B4 <sub>H</sub> |

#### (1) RAMEAD - RAM ECC error address register

The 16-bit RAMEAD register holds the lower 16 bit of the address of the RAM location, where an error was detected first.

Access This register can be read in 16-bit units.

Address FFFF F8B0<sub>H</sub>

Initial Value 0000<sub>H</sub>

| 15 | 14       | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    | RAMEADDR |    |    |    |    |   |   |   |   | 0 | 0 |   |   |   |   |

#### Table 3-16 RAMEAD register contents

| Bit<br>Position | Bit Name | Function                                          |
|-----------------|----------|---------------------------------------------------|
| 15 to 2         | RAMEADDR | 16-bit address of first detection of a RAM error. |

The address of the first error detection is stored in RAMEAD. At the same time the interrupt flag INTERRF.INTERR1 is set to 1. Additionally the erroneous byte location is indicated in the RAMEDLR register.

This register is not overwritten by a new error detection until

- the INTERRF.INTERR1 is cleared to 0. Thus no new error is signaled by interrupt INTDEDR until the INTERRF.INTERR1 is cleared to 0.
- RAMEAD is cleared to 0000<sub>H</sub> by any reset.

Afterwards the lower 16 bit of a new ECC detection address can be stored and a new INTDEDR interrupt can be generated.



### (2) RAMEDLR - RAM ECC error data location register

RAMEDLR indicates which byte of the 32-bit data byte at address RAMEAD has generated an error.

Access This register can be read in 8-bit units.

Address FFFF F8B2<sub>H</sub>

Initial Value 00<sub>H</sub>

| 7 | 6 | 5 | 4 | 3      | 2      | 1      | 0      |
|---|---|---|---|--------|--------|--------|--------|
| 0 | 0 | 0 | 0 | REBEN3 | REBEN2 | REBEN1 | REBEN0 |
| R | R | R | R | R      | R      | R      | R      |

### Table 3-17 RAMEDLR register contents

| Bit<br>Position | Bit Name | Function                                                                                                                         |
|-----------------|----------|----------------------------------------------------------------------------------------------------------------------------------|
| 3               | REBEN3   | ECC error status in data bits 31 to 24:<br>0: ECC error did not occur in bits 31 to 24<br>1: ECC error occurred in bits 31 to 24 |
| 2               | REBEN2   | ECC error status in data bits 23 to 16:<br>0: ECC error did not occur in bits 23 to 16<br>1: ECC error occured in bits 23 to 16  |
| 1               | REBEN1   | ECC error status in data bits 15 to 8:<br>0: ECC error did not occur in bits 15 to 8<br>1: ECC error occured in bits 15 to 8     |
| 0               | REBEN0   | ECC error status in data bits 7 to 0:<br>0: ECC error did not occur in bits 7 to 0<br>1: ECC error occured in bits 7 to 0        |

The content of RAMEDLR is related to the error detection address in RAMEAD, thus only valid after an error detection interrupt INTDEDR, i.e. if INTERRF.INTERR1 = 1.



### (3) RAMECC - RAM ECC control register

RAMECC control the operation of the RAM ECC function.

Writing to this register is only possible immediately after writing to the associated write protection register. First write to the PRCMD register. The contents is ignored. Then, you are permitted to write once to the RAMECC register. This must be done immediately after writing to the PRCMD register. After the second write action, or if the second write action does not follow immediately, all protected registers are write-locked again.

Access This register can be read/written in 8-bit and 1-bit units.

Address FFFF F8B4<sub>H</sub>

Initial Value 00<sub>H</sub>

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|---|---|---|---|---|---|---|--------|
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | RAEENB |
| R | R | R | R | R | R | R | R      |

#### Table 3-18 RAMECC register contents

| Bit<br>Position | Bit Name | Function                                                                    |
|-----------------|----------|-----------------------------------------------------------------------------|
| 0               | RAEENB   | ECC function enable:<br>0: ECC function enabled<br>1: ECC function disabled |

Caution 1. Before modifying RAEENB make sure to stop any DMA transfers.

2. Confirm correct setting of RAEENB by re-reading this bit after its modification.



### 3.6.3 RAM ECC function check

In order to check the functionality of the RAM ECC error detection proceed as described below:

- 1. enable ECC function by RAMECC.RAEENB = 0
- 2. write some data word (e.g. data\_1) to the RAM: correct ECC wil be generated
- 3. disable ECC function by RAMECC.RAEENB = 1
- 4. write another data word (e.g. data\_2) to the RAM address of the first data word data\_1: no new ECC will be generated, thus ECC does not fit to data\_2
- 5. enable ECC function by RAMECC.RAEENB = 0
- 6. read data\_2: a maskable or non-maskable ECC error interrupt should be generated



### 3.6.4 Recommended use of data address space

When accessing operand data in the data space, one register has to be used for address generation. This register is called pointer register. With relative addressing, an instruction can access operand data at all addresses that lie in the range of  $\pm 32$  KB relative to the address in the pointer register.

By this offset addressing method load/store instructions can be accommodated in a single 32-bit instruction word, resulting in faster program execution and smaller code size.

To enhance the efficiency of using the pointer in consideration of the memory map, the following is recommended:

For efficient use of the relative addressing feature, the data segments should be located in the address range FFFF  $8000_H$  to FFFF EFFF<sub>H</sub> and  $0000\ 0000_H$  to  $0000\ 7FFF_H$ . The peripheral I/O registers and the internal RAM is aligned to the upper bound, thus the registers and a part of the RAM can be addressed via relative addressing, with base address 0 (r0).

It is recommended to locate flash memory data segments in the area up to 0000  $7FFF_H$ , so access to these constant data can utilize also relative addressing.

Use the r0 register as pointer register for operand addressing. Since the r0 register is fixed to zero by hardware, it can be used as a pointer register and, at the same time, for any other purposes, where a zero register is required. Thus, no other general purpose register has to be reserved as pointer register.



### Figure 3-7 Example application of wrap-around



### 3.7 Write Protected Registers

Write protected registers are protected from inadvertent write access due to erroneous program execution, etc. Write access to a write protected register is only given immediately after writing to a corresponding write enable register. For a write access to the write protected registers you have to use the following instructions:

- 1. Store instruction (ST/SST instruction)
- 2. Bit operation instruction (SET1/CLR1/NOT1 instruction)

When *reading* write protected registers, no special sequence is required.

The following table gives an overview of the write protected registers and their corresponding write enable registers.

For some registers, incorrect store operations can be checked by a flag of the corresponding status register. This is also marked in the table below.

| Write protected register                     | Shortcut                                   | Corresponding write enable register | Shortcut | For details see                            |  |
|----------------------------------------------|--------------------------------------------|-------------------------------------|----------|--------------------------------------------|--|
| Port group control registers of port group 5 | P5, PM5, PMC5,<br>PESC5, ESOST5,<br>PESMK5 | Command register                    | PRCMD    | "Pin Functions" on<br>page 23              |  |
| Port group control registers of port group 6 | P6, PM6, PMC6,<br>PESC6, ESOST6,<br>PESMK6 | Command register                    | FROMD    |                                            |  |
| RAM ECC control register                     | RAMECC                                     | Command register                    | PRCMD    | "RAM ECC error<br>detection" on<br>page 91 |  |
| Clock Monitor mode<br>register               | CLM                                        | Command register                    | PRCMD    | "Clock Generator"<br>on page 148           |  |
| Data flash control register                  | DFLCTL                                     | Command register                    | PRCMD    | <i>"Flash Memory"</i><br>on page 159       |  |

Table 3-19 Overview of write protected registers

**Example** Write to port register P5:

PRCMD = 0x5A;P5 = 0x80;

**Note** Make sure that the compiler generates two consecutive assembler "store" instructions to PRCMD and the protected register (P5 in the above example) from the associated C statements.

Ensure to check the bit PHS.PRERR to be "0", as this indicates a successful write to the protected register.

Since any action between writing to a write enable register and writing to a protected register destroys this sequence, the effects of interrupts and DMA transfers have to be considered:

 Interrupts: After writing to PRCMD no maskable interrupts will be acknowledged, until the subsequent instruction has been executed. Thus a maskable interrupt can not destroy the sequence.

However, any non-maskable interrupt can still be acknowledged.

RENESAS

#### • DMA:

In the above example, DMA transfers can still take place. They may destroy the sequence.

If appropriate, you may disable DMA transfers in advance. Otherwise you must check whether writing to the protected register was successful. To do so, check the status via the status register, if available, or by reading back the protected register.



## Chapter 4 Interrupt Controller (INTC)

This controller is provided with a dedicated Interrupt Controller (INTC) for interrupt servicing and can process a large amount of maskable and up to five non-maskable interrupt requests.

An interrupt is an event that occurs independently of program execution, and an exception is an event whose occurrence is dependent on program execution. Generally, an exception takes precedence over an interrupt.

This controller can process interrupt requests from the on-chip peripheral hardware and external sources. Moreover, exception processing can be started by the TRAP instruction (software exception) or by generation of an exception event (i.e. fetching of an illegal opcode) (exception trap).

Eight levels of software-programmable priorities can be specified for each interrupt request. Starting of interrupt servicing takes no fewer than 4 system clocks after the generation of an interrupt request.

### 4.1 Features

- Interrupts
  - Non-maskable interrupts: up to 4 sources (depending on whether interrupt sharing is enabled or not)
  - Maskable interrupts:
    - internal peripherals: 98 sources
    - external: 13 sources
  - 8 levels of programmable priorities (maskable interrupts)
  - Multiple interrupt control according to priority
  - Masks can be specified for each maskable interrupt request
  - Noise elimination, edge detection and valid edge specification, level detection for external interrupt request signals
- Exceptions
  - Software exceptions: 2 channels with each 16 sources
  - Exception traps: 1 source (illegal opcode exception)



|                       |                                      | Inte                | rrupt/Exception Source               | Default                       | Exception | Handler                             | Restored  |          |  |
|-----------------------|--------------------------------------|---------------------|--------------------------------------|-------------------------------|-----------|-------------------------------------|-----------|----------|--|
| Туре                  | Name                                 | Control<br>Register | Generating Source                    | Generating<br>Unit            | Priority  | Code                                | Address   | PC       |  |
| Reset                 | RESET                                | -                   | RESET input                          | Pin                           | -         | 0000H                               | 00000000H | undef.   |  |
| Non-                  | NMI                                  | -                   | P00 NMI Input                        | Pin                           |           |                                     |           |          |  |
| maskable              | INTDEDF <sup>a</sup>                 | -                   | Double error detection               | Flash<br>memory               |           |                                     |           |          |  |
|                       | INTDEDR <sup>a</sup>                 | -                   | Double error detection               | RAM                           | -         | 0010H                               | 00000010H | nextPC   |  |
|                       | INTOSD <sup>a</sup>                  | -                   | Oscillator stop detection            | Clock<br>Monitor              |           |                                     |           |          |  |
| Software<br>exception | TRAP0n<br>(n = 0 to F <sub>H</sub> ) | -                   | TRAP instruction                     | -                             | -         | 004nH<br>(n = 0 to F <sub>H</sub> ) | 00000040H | nextPC   |  |
|                       | TRAP1n<br>(n = 0 to F <sub>H</sub> ) | -                   | TRAP instruction                     | -                             | -         | 005nH<br>(n = 0 to F <sub>H</sub> ) | 00000050H | nextPC   |  |
| Exception             | ILGOP                                | -                   | lllegal opcode                       | -                             |           | 000011                              | 0000060H  | n av tDO |  |
| trap                  | DBTRAP                               | -                   | DBTRAP instruction                   | -                             | -         | 0060H                               |           | nextPC   |  |
| Maskable              | INTDEDF <sup>a</sup>                 | ERRIC               | Double error detection               | Flash<br>memory               |           |                                     |           |          |  |
|                       | INTDEDR <sup>a</sup>                 | 1                   | Double error detection               | RAM                           | 0         | 0080H                               | 00000080H | nextPC   |  |
|                       | INTOSD <sup>a</sup>                  | OSDIC               | Oscillator stop detection            | Clock<br>Monitor              | 1         | 0090H                               | 00000090H | nextPC   |  |
|                       | INTP0                                | PICO                | External interrupt 0                 | Pin                           | 2         | 00A0H                               | 000000A0H | next PC  |  |
|                       | INTP1                                | PIC1                | External interrupt 1                 | Pin                           | 3         | 00B0H                               | 000000B0H | next PC  |  |
|                       | INTP2                                | PIC2                | External interrupt 2                 | Pin                           | 4         | 00C0H                               | 000000C0H | next PC  |  |
|                       | INTP3                                | PIC3                | External interrupt 3                 | Pin                           | 5         | 00D0H                               | 000000D0H | next PC  |  |
|                       | INTUC0R <sup>b</sup>                 | PIC4                | UARTCO receive complete<br>interrupt | UARTC0<br>(DMAC) <sup>c</sup> | 6         | 00E0H                               | 000000E0H | next PC  |  |
|                       | INTP4 <sup>b</sup>                   | 1                   | External interrupt 4                 | Pin                           |           |                                     |           |          |  |
|                       | INTUC1R <sup>b</sup>                 | PIC5                | UARTC1 receive complete<br>interrupt | UARTC1<br>(DMAC) <sup>c</sup> | 7         | 00F0H                               | 000000F0H | next PC  |  |
|                       | INTP5 <sup>b</sup>                   | 1                   | External interrupt 5                 | Pin                           |           |                                     |           |          |  |
|                       | INTP6                                | PIC6                | External interrupt 6                 | Pin                           | 8         | 0100H                               | 00000100H | next PC  |  |
|                       | INTP7                                | PIC7                | External interrupt 7                 | Pin                           | 9         | 0110H                               | 00000110H | next PC  |  |
|                       | INTP8                                | PIC8                | External interrupt 8                 | Pin                           | 10        | 0120H                               | 00000120H | next PC  |  |
|                       | INTP9                                | PIC9                | External interrupt 9                 | Pin                           | 11        | 0130H                               | 00000130H | next PC  |  |
|                       | INTP10                               | PIC10               | External interrupt 10                | Pin                           | 12        | 0140H                               | 00000140H | next PC  |  |
|                       | INTP11                               | PIC11               | External interrupt 11                | Pin                           | 13        | 0150H                               | 00000150H | next PC  |  |
|                       | INTP12                               | PIC12               | External interrupt 12                | Pin                           | 14        | 0160H                               | 00000160H | next PC  |  |

 Table 4-1
 Interrupt/exception source list (1/5)



|          |           | Inte                | rrupt/Exception Source            |                    | Default  | Execution         | Handlar            | Postarad       |
|----------|-----------|---------------------|-----------------------------------|--------------------|----------|-------------------|--------------------|----------------|
| Туре     | Name      | Control<br>Register | Generating Source                 | Generating<br>Unit | Priority | Exception<br>Code | Handler<br>Address | Restored<br>PC |
| Maskable | INTTSOOV  | TSOOVIC             | TMS0 overflow interrupt           | TMS0               | 15       | 0170H             | 00000170H          | next PC        |
|          | INTTSOCCO | TSOCCICO            | TMS0 capture compare<br>channel 0 | TMS0               | 16       | 0180H             | 00000180H          | next PC        |
|          | INTTSOCC1 | TS0CCIC1            | TMS0 capture compare<br>channel 1 | TMS0               | 17       | 0190H             | 00000190H          | next PC        |
|          | INTTSOCC2 | TS0CCIC2            | TMS0 capture compare<br>channel 2 | TMS0               | 18       | 01A0H             | 000001A0H          | next PC        |
|          | INTTSOCC3 | TS0CCIC3            | TMS0 capture compare channel 3    | TMS0               | 19       | 01B0H             | 000001B0H          | next PC        |
|          | INTTSOCC4 | TS0CCIC4            | TMS0 capture compare<br>channel 4 | TMS0               | 20       | 01C0H             | 000001C0H          | next PC        |
|          | INTTSOCC5 | TS0CCIC5            | TMS0 capture compare<br>channel 5 | TMS0               | 21       | 01D0H             | 000001D0H          | next PC        |
|          | INTTSOCDO | TSOCDICO            | TS0CNT top reversal               | TMS0               | 22       | 01E0H             | 000001E0H          | next PC        |
|          | INTTS00D  | TSOODIC             | TS0CNT bottom reversal            | TMS0               | 23       | 01F0H             | 000001F0H          | next PC        |
|          | INTTS0ER  | TSOERIC             | TMS0 error detection              | TMS0               | 24       | 0200H             | 00000200H          | next PC        |
|          | INTTSOWN  | TSOWNIC             | TMS0 warning interrupt            | TMS0               | 25       | 0210H             | 00000210H          | next PC        |
|          | INTTS10V  | TS10VIC             | TMS1 overflow interrupt           | TMS1               | 26       | 0220H             | 00000220H          | next PC        |
|          | INTTS1CC0 | TS1CCIC0            | TMS1 capture compare channel 0    | TMS1               | 27       | 0230H             | 00000230H          | next PC        |
|          | INTTS1CC1 | TS1CCIC1            | TMS1 capture compare<br>channel 1 | TMS1               | 28       | 0240H             | 00000240H          | next PC        |
|          | INTTS1CC2 | T\$1CCIC2           | TMS1 capture compare<br>channel 2 | TMS1               | 29       | 0250H             | 00000250H          | next PC        |
|          | INTTS1CC3 | TS1CCIC3            | TMS1 capture compare channel 3    | TMS1               | 30       | 0260H             | 00000260H          | next PC        |
|          | INTTS1CC4 | TS1CCIC4            | TMS1 capture compare<br>channel 4 | TMS1               | 31       | 0270H             | 00000270H          | next PC        |
|          | INTTS1CC5 | TS1CCIC5            | TMS1 capture compare<br>channel 5 | TMS1               | 32       | 0280H             | 00000280H          | next PC        |
|          | INTTS1CD0 | TS1CDIC0            | TS1CNT top reversal               | TMS1               | 33       | 0290H             | 00000290H          | next PC        |
|          | INTTS10D  | T\$10DIC            | TS1CNT bottom reversal            | TMS1               | 34       | 02A0H             | 000002A0H          | next PC        |
|          | INTTS1ER  | TS1ERIC             | TMS1 error detection              | TMS1               | 35       | 02B0H             | 000002B0H          | next PC        |
|          | INTTS1WN  | TS1WNIC             | TMS1 warning interrupt            | TMS1               | 36       | 02C0H             | 000002C0H          | next PC        |
|          | INTTTOOV  | TTOOVIC             | TMT0 overflow interrupt           | TMT0               | 37       | 02D0H             | 000002D0H          | nextPC         |
|          | INTTTOCCO | TTOCCICO            | TMT0 capture compare<br>channel 0 | TMT0               | 38       | 02E0H             | 000002E0H          | nextPC         |
|          | INTTTOCC1 | TT0CCIC1            | TMT0 capture compare<br>channel 1 | TMT0               | 39       | 02F0H             | 000002F0H          | nextPC         |
|          | INTTTOEC  | TTOECIC             | TMT0 encoder clear interrupt      | TMT0               | 40       | 0300H             | 00000300H          | nextPC         |

 Table 4-1
 Interrupt/exception source list (2/5)



|          |            | Inte                | rrupt/Exception Source            | Default            | Exception | Handler | Restored  |        |
|----------|------------|---------------------|-----------------------------------|--------------------|-----------|---------|-----------|--------|
| Туре     | Name       | Control<br>Register | Generating Source                 | Generating<br>Unit | Priority  | Code    | Address   | PC     |
| Maskable | INTTT10V   | TT10VIC             | TMT1 overflow interrupt           | TMT1               | 41        | 0310H   | 00000310H | nextPC |
|          | INTTT1CC0  | TT1CCIC0            | TMT1 capture compare<br>channel 0 | TMT1               | 42        | 0320H   | 00000320H | nextPC |
|          | INTTT1CC1  | TT1CCIC1            | TMT1 capture compare<br>channel 1 | TMT1               | 43        | 0330H   | 00000330H | nextPC |
|          | INTTT1EC   | TT1ECIC             | TMT1 encoder clear interrupt      | TMT1               | 44        | 0340H   | 00000340H | nextPC |
|          | INTTAA0OV  | TAA0OVIC            | TAA0 overflow interrupt           | TAA0               | 45        | 0350H   | 00000350H | nextPC |
|          | INTTAAOCCO | TAA0CCIC0           | TAA0 capture compare<br>channel 0 | TAA0               | 46        | 0360H   | 00000360H | nextPC |
|          | INTTAA0CC1 | TAA0CCIC1           | TAA0 capture compare<br>channel 1 | TAA0               | 47        | 0370H   | 00000370H | nextPC |
|          | INTTAA10V  | TAA10VIC            | TAA1 overflow interrupt           | TAA1               | 48        | 0380H   | 00000380H | nextPC |
|          | INTTAA1CC0 | TAA1CCIC0           | TAA1 capture compare<br>channel 0 | TAA1               | 49        | 0390H   | 00000390H | nextPC |
|          | INTTAA1CC1 | TAA1CCIC1           | TAA1 capture compare<br>channel 1 | TAA1               | 50        | 03A0H   | 000003A0H | nextPC |
|          | INTTAA2OV  | TAA2OVIC            | TAA2 overflow interrupt           | TAA2               | 51        | 03B0H   | 000003B0H | nextPC |
|          | INTTAA2CC0 | TAA2CCIC0           | TAA2 capture compare<br>channel 0 | TAA2               | 52        | 03C0H   | 000003C0H | nextPC |
|          | INTTAA2CC1 | TAA2CCIC1           | TAA2 capture compare<br>channel 1 | TAA2               | 53        | 03D0H   | 000003D0H | nextPC |
|          | INTTAA3OV  | TAA3OVIC            | TAA3 overflow interrupt           | TAA3               | 54        | 03E0H   | 000003E0H | nextPC |
|          | INTTAA3CC0 | TAA3CCIC0           | TAA3 capture compare<br>channel 0 | TAA3               | 55        | 03F0H   | 000003F0H | nextPC |
|          | INTTAA3CC1 | TAA3CCIC1           | TAA3 capture compare<br>channel 1 | TAA3               | 56        | 0400H   | 00000400H | nextPC |
|          | INTTAA4OV  | TAA4OVIC            | TAA4 overflow interrupt           | TAA4               | 57        | 0410H   | 00000410H | nextPC |
|          | INTTAA4CC0 | TAA4CCIC0           | TAA4 capture compare<br>channel 0 | TAA4               | 58        | 0420H   | 00000420H | nextPC |
|          | INTTAA4CC1 | TAA4CCIC1           | TAA4 capture compare<br>channel 1 | TAA4               | 59        | 0430H   | 00000430H | nextPC |
|          | INTTAA5OV  | TAA5OVIC            | TAA5 overflow interrupt           | TAA5               | 60        | 0440H   | 00000440H | nextPC |
|          | INTTAA5CC0 | TAA5CCIC0           | TAA5 capture compare<br>channel 0 | TAA5               | 61        | 0450H   | 00000450H | nextPC |
|          | INTTAA5CC1 | TAA5CCIC1           | TAA5 capture compare<br>channel 1 | TAA5               | 62        | 0460H   | 00000460H | nextPC |
|          | INTTAA6OV  | TAA6OVIC            | TAA6 overflow interrupt           | TAA6               | 63        | 0470H   | 00000470H | nextPC |
|          | INTTAA6CC0 | TAA6CCIC0           | TAA6 capture compare<br>channel 0 | TAA6               | 64        | 0480H   | 00000480H | nextPC |
|          | INTTAA6CC1 | TAA6CCIC1           | TAA6 capture compare<br>channel 1 | TAA6               | 65        | 0490H   | 00000490H | nextPC |

 Table 4-1
 Interrupt/exception source list (3/5)



|          | Interrupt/Exception Source |                     |                                     |                              | Default  | Exception | llandlar           | Destared       |
|----------|----------------------------|---------------------|-------------------------------------|------------------------------|----------|-----------|--------------------|----------------|
| Туре     | Name                       | Control<br>Register | Generating Source                   | Generating<br>Unit           | Priority | Code      | Handler<br>Address | Restored<br>PC |
| Maskable | INTTAA7OV                  | TAA7OVIC            | TAA7 overflow interrupt             | TAA7                         | 66       | 04A0H     | 000004A0H          | nextPC         |
|          | INTTAA7CC0                 | TAA7CCIC0           | TAA7 capture compare<br>channel 0   | TAA7                         | 67       | 04B0H     | 000004B0H          | nextPC         |
|          | INTTAA7CC1                 | TAA7CCIC1           | TAA7 capture compare<br>channel 1   | TAA7                         | 68       | 04C0H     | 000004C0H          | nextPC         |
|          | INTTAA8OV                  | TAA80VIC            | TAA8 overflow interrupt             | TAA8                         | 69       | 04D0H     | 000004D0H          | nextPC         |
|          | INTTAA8CC0                 | TAA8CCIC0           | TAA8 capture compare<br>channel 0   | TAA8                         | 70       | 04E0H     | 000004E0H          | nextPC         |
|          | INTTAA8CC1                 | TAA8CCIC1           | TAA8 capture compare<br>channel 1   | TAA8                         | 71       | 04F0H     | 000004F0H          | nextPC         |
|          | INTTAA9OV                  | TAA9OVIC            | TAA9 overflow interrupt             | TAA9                         | 72       | 0500H     | 00000500H          | nextPC         |
|          | INTTAA9CC0                 | TAA9CCIC0           | TAA9 capture compare<br>channel 0   | TAA9                         | 73       | 0510H     | 00000510H          | nextPC         |
|          | INTTAA9CC1                 | TAA9CCIC1           | TAA9 capture compare<br>channel 1   | TAA9                         | 74       | 0520H     | 00000520H          | nextPC         |
|          | INTBRG0 <sup>b</sup>       | BRGIC               | BRG0 match                          | BRG0                         | 75       | 052011    | 00000530H          | nextPC         |
|          | INTBRG1 <sup>b</sup>       |                     | BRG1 match                          | BRG1                         | 75       | 0530H     |                    |                |
|          | INTBRG2                    | BRGIC2              | BRG2 match                          | BRG2                         | 76       | 0540H     | 00000540H          | nextPC         |
|          | INTC0ERR                   | COERRIC             | CAN0 error interrupt                | CAN0                         | 83       | 05B0H     | 000005B0H          | nextPC         |
|          | INTCOWUP                   | COWUPIC             | CAN0 wake up interrupt              | CAN0                         | 84       | 05C0H     | 000005C0H          | nextPC         |
|          | INTCOREC                   | CORECIC             | CAN0 receive interrupt              | CAN0                         | 85       | 05D0H     | 000005D0H          | nextPC         |
|          | INTCOTRX                   | COTRXIC             | CAN0 transmit interrupt             | CAN0                         | 86       | 05E0H     | 000005E0H          | nextPC         |
|          | INTC1ERR                   | C1ERRIC             | CAN1 error interrupt                | CAN1                         | 87       | 05F0H     | 000005F0H          | nextPC         |
|          | INTC1WUP                   | C1WUPIC             | CAN1 wake up interrupt              | CAN1                         | 88       | 0600H     | 00000600H          | nextPC         |
|          | INTC1REC                   | C1RECIC             | CAN1 receive interrupt              | CAN1                         | 89       | 0610H     | 00000610H          | nextPC         |
|          | INTC1TRX                   | C1TRXIC             | CAN1 transmit interrupt             | CAN1                         | 90       | 0620H     | 00000620H          | nextPC         |
|          | Reserved                   | -                   | Reserved                            | -                            | 91       | 0630H     | 00000630H          | nextPC         |
|          | Reserved                   | -                   | Reserved                            | -                            | 92       | 0640H     | 00000640H          | nextPC         |
|          | Reserved                   | -                   | Reserved                            | -                            | 93       | 0650H     | 00000650H          | nextPC         |
|          | Reserved                   | -                   | Reserved                            | -                            | 94       | 0660H     | 00000660H          | nextPC         |
|          | Reserved                   | -                   | Reserved                            | -                            | 95       | 0670H     | 00000670H          | nextPC         |
|          | Reserved                   | -                   | Reserved                            | -                            | 96       | 0680H     | 00000680H          | nextPC         |
|          | Reserved                   | -                   | Reserved                            | -                            | 97       | 0690H     | 00000690H          | nextPC         |
|          | Reserved                   | -                   | Reserved                            | -                            | 98       | 06A0H     | 000006A0H          | nextPC         |
|          | INTCBOT                    | CBOTIC              | CSIB0 transmit interrupt            | CSIB0<br>(DMAC) <sup>c</sup> | 99       | 06B0H     | 000006B0H          | nextPC         |
|          | INTCBOR                    | CBORIC              | CSIB0 receive complete<br>interrupt | CSIB0<br>(DMAC) <sup>c</sup> | 100      | 06C0H     | 000006C0H          | nextPC         |
|          | INTCBORE                   | CBOREIC             | CSIB0 receive error interrupt       | CSIB0                        | 101      | 06D0H     | 000006D0H          | nextPC         |

 Table 4-1
 Interrupt/exception source list (4/5)



|          | Interrupt/Exception Source |                     |                                     |                               |                     | Freedor           | Handler   | Restored |
|----------|----------------------------|---------------------|-------------------------------------|-------------------------------|---------------------|-------------------|-----------|----------|
| Туре     | Name                       | Control<br>Register | Generating Source                   | Generating<br>Unit            | Default<br>Priority | Exception<br>Code | Address   | PC       |
| Maskable | INTCB1T                    | CB1TIC              | CSIB1 transmit interrupt            | CSIB1<br>(DMAC) <sup>c</sup>  | 102                 | 06E0H             | 000006E0H | nextPC   |
|          | INTCB1R                    | CB1RIC              | CSIB1 receive complete<br>interrupt | CSIB1<br>(DMAC) <sup>c</sup>  | 103                 | 06F0H             | 000006F0H | nextPC   |
|          | INTCB1RE                   | CB1REIC             | CSIB1 receive error interrupt       | CSIB1                         | 104                 | 0700H             | 00000700H | nextPC   |
|          | INTCE00F                   | CE00FIC             | CSIE0 overflow interrupt            | CSIE0                         | 105                 | 0710H             | 00000710H | nextPC   |
|          | INTCEOC                    | CEOCIC              | CSIE0 transfer end interrupt        | CSIE0<br>(DMAC) <sup>c</sup>  | 106                 | 0720H             | 00000720H | nextPC   |
|          | INTCE10F                   | CE10FIC             | CSIE1 overflow interrupt            | CSIE1                         | 107                 | 0730H             | 00000730H | nextPC   |
|          | INTCE1C                    | CE1CIC              | CSIE1 transfer end interrupt        | CSIE1<br>(DMAC) <sup>c</sup>  | 108                 | 0740H             | 00000740H | nextPC   |
|          | INTUCORE                   | UCOREIC             | UARTC0 receive error<br>interrupt   | UARTC0                        | 109                 | 0750H             | 00000750H | nextPC   |
|          | INTUCOT                    | UCOTIC              | UARTC0 transmit interrupt           | UARTC0<br>(DMAC) <sup>c</sup> | 110                 | 0760H             | 00000760H | nextPC   |
|          | INTUC1RE                   | UC1REIC             | UARTC1 receive error<br>interrupt   | UARTC1                        | 111                 | 0770H             | 00000770H | nextPC   |
|          | INTUC1T                    | UC1TIC              | UARTC1 transmit interrupt           | UARTC1<br>(DMAC) <sup>c</sup> | 112                 | 0780H             | 00000780H | nextPC   |
|          | INTAD0                     | ADIC0               | ADC0 end of conversion              | ADC0<br>(DMAC) <sup>c</sup>   | 113                 | 0790H             | 00000790H | nextPC   |
|          | INTAD1                     | ADIC1               | ADC1 end of conversion              | ADC1<br>(DMAC) <sup>c</sup>   | 114                 | 07A0H             | 000007A0H | nextPC   |
|          | INTDMA2                    | DMAIC2              | DMA2 transmission end               | DMAC                          | 115                 | 07B0H             | 000007B0H | nextPC   |
|          | INTDMA3                    | DMAIC3              | DMA3 transmission end               | DMAC                          | 116                 | 07C0H             | 000007C0H | nextPC   |

| Table 4-1 Interrupt/exception source list (5/5) | Table 4-1 | Interrupt/exception source list (5/5 |
|-------------------------------------------------|-----------|--------------------------------------|
|-------------------------------------------------|-----------|--------------------------------------|

a) Depending on the setting of INTSEL.ISR, this interrupt source generates an NMI or a maskable interrupt. For more information see *"Interrupt Sharing" on page 127*.

b) This is a shared interrupt. For details see "Interrupt Sharing" on page 127.

c) If this interrupt is defined as a DMA trigger, it is generated by the corresponding DMA completion interrupt IN-TDMAn instead of the original interrupt source. For further details refer to "DMA Functions (DMA Controller)" on page 211

| Note | 1. | Default priority: | The priority order when two or more maskable<br>interrupt requests are generated at the same time.<br>The highest priority is 0.                                                                                                                                                                                         |
|------|----|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | 2. | Restored PC:      | The value of the PC saved to EIPC or FEPC when<br>interrupt/exception processing is started. However, the<br>value of the PC saved when an interrupt is<br>acknowledged during division (DIV, DIVH, DIVU,<br>DIVHU) instruction execution is the value of the PC of<br>the current instruction (DIV, DIVH, DIVU, DIVHU). |
|      | 3. | nextPC:           | The PC value that starts the processing following interrupt/exception processing.                                                                                                                                                                                                                                        |

4. The execution address of the illegal instruction when an illegal opcode exception occurs is calculated by (Restored PC - 4).

RENESAS

### 4.2 Non-Maskable Interrupts

A non-maskable interrupt request is acknowledged unconditionally, even when interrupts are in the interrupt disabled (DI) status.

Non-maskable interrupts of this microcontroller are available for the following requests:

### Table 4-2 Non-maskable interrupts

| Interrupt Source | Generating Unit | Comment                                                                                                      |  |  |
|------------------|-----------------|--------------------------------------------------------------------------------------------------------------|--|--|
| NMI              | Pin             | When the valid edge specified by bits<br>INTM0.ESN[1:0] is detected on the NMI pin,<br>the interrupt occurs. |  |  |
| INTDEDF          | Flash memory    | These interrupt sources only generate a non-                                                                 |  |  |
| INTDEDR          | RAM             | <i>maskable</i> interrupt if interrupt sharing is enabled for non-maskable interrupts. See                   |  |  |
| INTOSD           | Clock Monitor   | "Interrupt Sharing" on page 127.                                                                             |  |  |

**Note** If a NMI is generated while NMI is being serviced, the service is executed as follows:

The new NMI request is held pending regardless of the value of the PSW.NP bit. The pending NMIVC request is acknowledged after servicing of the current NMI request has finished (after execution of the RETI instruction).

**Caution** If PSW.NP is cleared by the LDSR instruction while a non-maskable interrupt is being serviced, a following NMI interrupt cannot be acknowledged correctly.



Figure 4-1 Example of non-maskable interrupt request acknowledgement operation: multiple NMI requests generated at the same time





Figure 4-2 Example of non-maskable interrupt request acknowledgement operation: NMI request generated during NMI servicing

### 4.2.1 Operation

If a non-maskable interrupt is generated, the CPU performs the following processing, and transfers control to the handler routine:

- 1. Saves the restored PC to FEPC.
- 2. Saves the current PSW to FEPSW.
- 3. Writes exception code 0010H to the higher halfword (FECC) of ECR.
- 4. Sets the NP and ID bits of the PSW and clears the EP bit.
- 5. Sets the handler address corresponding to the non-maskable interrupt to the PC, and transfers control.

The processing configuration of a non-maskable interrupt is shown in *Figure 4-3*.





Figure 4-3 Processing configuration of non-maskable interrupt



### 4.2.2 Restore

Execution is restored from the non-maskable interrupt (NMI) processing by the RETI instruction.

When the RETI instruction is executed, the CPU performs the following processing, and transfers control to the address of the restored PC.

- 1. Restores the values of the PC and the PSW from FEPC and FEPSW, respectively, because the EP bit of the PSW is 0 and the NP bit of the PSW is 1.
- 2. Transfers control back to the address of the restored PC and PSW.

Figure 4-4 illustrates how the RETI instruction is processed.



Figure 4-4 RETI instruction processing

**Caution** When the PSW.EP bit and PSW.NP bit are changed by the LDSR instruction during non-maskable interrupt processing, in order to restore the PC and PSW correctly during recovery by the RETI instruction, it is necessary to set PSW.EP back to 0 and PSW.NP back to 1 using the LDSR instruction immediately before the RETI instruction.

Note The solid line indicates the CPU processing flow.



### 4.2.3 Non-maskable interrupt status flag (NP)

The NP flag is a status flag that indicates that non-maskable interrupt (NMI) processing is under execution.

This flag is set when an NMI interrupt has been acknowledged, and masks all interrupt requests and exceptions to prohibit multiple interrupts from being acknowledged.

Initial Value 00000020<sub>H</sub>

|     | 31                                      | 8 | 7  | 6  | 5  | 4   | 3  | 2  | 1 | 0 |
|-----|-----------------------------------------|---|----|----|----|-----|----|----|---|---|
| PSW | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0 | NP | EP | ID | SAT | CY | ٥V | S | Ζ |

| Bit position | Bit name | Function                                                                                                                                   |  |  |  |  |
|--------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 7            | NP       | Indicates whether NMI interrupt processing is in progress.<br>0: No NMI interrupt processing<br>1: NMI interrupt currently being processed |  |  |  |  |

### 4.2.4 NMI control

The NMI can be configured to generate an NMI upon a rising, falling or both edges at the NMI pin. To enable respectively disable the NMI and to configure the edge refer to *"Edge and Level Detection Configuration" on page 124*.



## 4.3 Maskable Interrupts

Maskable interrupt requests can be masked by interrupt control registers.

If two or more maskable interrupt requests are generated at the same time, they are acknowledged according to the default priority. In addition to the default priority, eight levels of priorities can be specified by using the interrupt control registers (programmable priority control).

When an interrupt request has been acknowledged, the acknowledgement of other maskable interrupt requests is disabled and the interrupt disabled (DI) status is set.

When the EI instruction is executed in an interrupt processing routine, the interrupt enabled (EI) status is set, which enables servicing of interrupts having a higher priority than the interrupt request in progress (specified by the interrupt control register). Note that only interrupts with a higher priority will have this capability; interrupts with the same priority level cannot be nested.

However, if multiple interrupts are executed, the following processing is necessary.

- 1. Save EIPC and EIPSW in memory or a general-purpose register before executing the EI instruction.
- 2. Execute the DI instruction before executing the RETI instruction, then reset EIPC and EIPSW with the values saved in (1).

## 4.3.1 Operation

If a maskable interrupt occurs by INT input, the CPU performs the following processing, and transfers control to a handler routine:

- 1. Saves the restored PC to EIPC.
- 2. Saves the current PSW to EIPSW.
- 3. Writes an exception code to the lower halfword of ECR (EICC).
- 4. Sets the ID bit of the PSW and clears the EP bit.
- 5. Sets the handler address corresponding to each interrupt to the PC, and transfers control.

The processing configuration of a maskable interrupt is shown in Figure 4-5.





Figure 4-5 Maskable interrupt processing

Note For the ISPR register, see "ISPR - In-service priority register" on page 122.

An INT input masked by the Interrupt Controllers and an INT input that occurs while another interrupt is being processed (when PSW.NP = 1 or PSW.ID = 1) are held pending internally by the Interrupt Controller. In such case, if the interrupts are unmasked, or when PSW.NP = 0 and PSW.ID = 0 as set by the RETI and LDSR instructions, input of the pending INT starts the new maskable interrupt processing.



## 4.3.2 Restore

Recovery from maskable interrupt processing is carried out by the RETI instruction.

When the RETI instruction is executed, the CPU performs the following steps, and transfers control to the address of the restored PC.

- 1. Restores the values of the PC and the PSW from EIPC and EIPSW because the EP bit of the PSW is 0 and the NP bit of the PSW is 0.
- 2. Transfers control to the address of the restored PC and PSW.

Figure 4-6 illustrates the processing of the RETI instruction.



Figure 4-6 RETI instruction processing

- Note 1. For the ISPR register, see "ISPR In-service priority register" on page 122.
  - 2. The solid lines show the CPU processing flow.

**Caution** When the PSW.EP bit and the PSW.NP bit are changed by the LDSR instruction during maskable interrupt processing, in order to restore the PC and PSW correctly during recovery by the RETI instruction, it is necessary to set PSW.EP back to 0 and PSW.NP back to 0 using the LDSR instruction immediately before the RETI instruction.



### 4.3.3 Priorities of maskable interrupts

This microcontroller provides multiple interrupt servicing in which an interrupt is acknowledged while another interrupt is being serviced. Multiple interrupts can be controlled by priority levels.

There are two types of priority level control: control based on the default priority levels, and control based on the programmable priority levels that are specified by the interrupt priority level specification bit (xxPRn) of the interrupt control register (xxICn). When two or more interrupts having the same priority level specified by the xxPRn bit are generated at the same time, interrupts are serviced in order depending on the priority level allocated to each interrupt request type (default priority level) beforehand. For more information, refer to the interrupt/exception source list table. The programmable priority control customizes interrupt requests into eight levels by setting the priority level specification flag.

Note that when an interrupt request is acknowledged, the ID flag of PSW is automatically set to 1. Therefore, when multiple interrupts are to be used, clear the ID flag to 0 beforehand (for example, by placing the EI instruction in the interrupt service program) to set the interrupt enable mode.





Figure 4-7 Example of processing in which another interrupt request is issued while an interrupt is being processed (1/2)





- Figure 4-8 Example of processing in which another interrupt request is issued while an interrupt is being processed (2/2)
  - **Caution** The values of the EIPC and EIPSW registers must be saved before executing multiple interrupts. When returning from multiple interrupt servicing, restore the values of EIPC and EIPSW after executing the DI instruction.
    - **Note** 1. <a> to <u> in the figures are the temporary names of interrupt requests shown for the sake of explanation.
      - 2. The default priority in the figure indicates the relative priority between two interrupt requests.

RENESAS



- Figure 4-9 Example of processing interrupt requests simultaneously generated
  - **Caution** The values of the EIPC and EIPSW registers must be saved before executing multiple interrupts. When returning from multiple interrupt servicing, restore the values of EIPC and EIPSW after executing the DI instruction.
    - **Note** <a> to <c> in the figure are the temporary names of interrupt requests shown for the sake of explanation.



### 4.3.4 xxICn - Maskable interrupts control register

An interrupt control register is assigned to each interrupt request (maskable interrupt) and sets the control conditions for each maskable interrupt request.

Access These registers can be read/written in 8-bit or 1-bit units.

Address refer to Table 4-4 on page 118

Initial Value 47<sub>H</sub>. These registers are cleared by any reset.

|          | 7   | 7  | 6   | 6   | ţ  | 5  | 4  | 1    | (      | 3   | 2   | 2   |     | 1   | (   | 0   |
|----------|-----|----|-----|-----|----|----|----|------|--------|-----|-----|-----|-----|-----|-----|-----|
| xxlCn    | xxl | Fn | xxN | 1Kn | (  | )  | (  | )    | (      | )   | ххF | PR2 | XXF | PR1 | XXF | PR0 |
|          | R/  | W  | R/  | W   | R/ | W  | R/ | W    | R/     | W   | R/  | W/W | R   | W/W | R/  | /W  |
|          | 15  | 14 | 13  | 12  | 11 | 10 | 9  | 8    | 7      | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| TSnCCR1/ |     |    |     |     |    |    | Co | mpar | e valu | e 1 |     |     |     |     |     |     |
| TSnCCR1A |     |    |     |     |    |    |    | R    | /W     |     |     |     |     |     |     |     |

#### Table 4-3 xxICn register contents

| Bit position | Bit name |                                            |                                                                                                                                                                                                           |       | Function                             |  |  |   |   |   |                   |
|--------------|----------|--------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--------------------------------------|--|--|---|---|---|-------------------|
| 7            | xxlFn    | 0: Interrup<br>1: Interrup<br>The flag xxI | This is an interrupt request flag.<br>0: Interrupt request not issued<br>1: Interrupt request issued<br>The flag xxIFn is reset automatically by the hardware if an interrupt request is<br>acknowledged. |       |                                      |  |  |   |   |   |                   |
| 6            | xxMKn    | 0: Enable                                  | his is an interrupt mask flag.<br>0: Enables interrupt processing<br>1: Disables interrupt processing (pending)                                                                                           |       |                                      |  |  |   |   |   |                   |
|              |          | 8 levels of p                              | B levels of priority order are specified for each interrupt.                                                                                                                                              |       |                                      |  |  |   |   |   |                   |
|              |          | xxPR2                                      | xxPR1                                                                                                                                                                                                     | xxPR0 | Interrupt priority specification bit |  |  |   |   |   |                   |
|              |          | 0                                          | 0                                                                                                                                                                                                         | 0     | Specifies level 0 (highest)          |  |  |   |   |   |                   |
|              |          |                                            |                                                                                                                                                                                                           |       |                                      |  |  | 0 | 0 | 1 | Specifies level 1 |
|              | xxPB2 to | 0                                          | 1                                                                                                                                                                                                         | 0     | Specifies level 2                    |  |  |   |   |   |                   |
| 2 to 0       | xxPR0    | 0                                          | 1                                                                                                                                                                                                         | 1     | Specifies level 3                    |  |  |   |   |   |                   |
|              |          | 1                                          | 0                                                                                                                                                                                                         | 0     | Specifies level 4                    |  |  |   |   |   |                   |
|              | 1        |                                            | 0                                                                                                                                                                                                         | 1     | Specifies level 5                    |  |  |   |   |   |                   |
|              |          | 1                                          | 1                                                                                                                                                                                                         | 0     | Specifies level 6                    |  |  |   |   |   |                   |
|              |          | 1                                          | 1                                                                                                                                                                                                         | 1     | Specifies level 7 (lowest)           |  |  |   |   |   |                   |
|              |          |                                            |                                                                                                                                                                                                           |       | -                                    |  |  |   |   |   |                   |

# **Note** xx: identification name of each peripheral unit. For a complete list of all interrupt control registers see *Table 4-4 on page 118*.

The address and bit of each interrupt control register is shown in the following table.



|           |          |          | Associated     |       |           |           |           |                                |
|-----------|----------|----------|----------------|-------|-----------|-----------|-----------|--------------------------------|
| Address   | Register | 7        | 6              | 5 - 3 | 2         | 1         | 0         | interrupt                      |
| FFFFF110H | ERRIC    | ERRIF    | ERRMK          | 0     | ERRPR2    | ERRPR1    | ERRPR0    | INTDEDF<br>INTDEDR<br>INTDEDFR |
| FFFFF112H | OSDIC    | OSDIF    | OSDMK          | 0     | OSDPR2    | OSDPR1    | OSDPR0    | INTOSD                         |
| FFFFF114H | PIC0     | PIF0     | PMK0           | 0     | PPR02     | PPR01     | PPR00     | INTP0                          |
| FFFFF116H | PIC1     | PIF1     | PMK1           | 0     | PPR12     | PPR11     | PPR10     | INTP1                          |
| FFFFF118H | PIC2     | PIF2     | PMK2           | 0     | PPR22     | PPR21     | PPR20     | INTP2                          |
| FFFFF11AH | PIC3     | PIF3     | PMK3           | 0     | PPR32     | PPR31     | PPR30     | INTP3                          |
| FFFFF11CH | PIC4     | PIF4     | PMK4           | 0     | PPR42     | PPR41     | PPR40     | INTUCOR<br>INTP4               |
| FFFFF11EH | PIC5     | PIF5     | PMK5           | 0     | PPR52     | PPR51     | PPR50     | INTUC1R<br>INTP5               |
| FFFFF120H | PIC6     | PIF6     | PMK6           | 0     | PPR62     | PPR61     | PPR60     | INTP6                          |
| FFFFF122H | PIC7     | PIF7     | PMK7           | 0     | PPR72     | PPR71     | PPR70     | INTP7                          |
| FFFFF124H | PIC8     | PIF8     | PMK8           | 0     | PPR82     | PPR81     | PPR80     | INTP8                          |
| FFFFF126H | PIC9     | PIF9     | PMK9           | 0     | PPR92     | PPR91     | PPR90     | INTP9                          |
| FFFFF128H | PIC10    | PIF10    | PMK10          | 0     | PPR102    | PPR101    | PPR100    | INTP10                         |
| FFFFF12AH | PIC11    | PIF11    | PMK11          | 0     | PPR112    | PPR111    | PPR110    | INTP11                         |
| FFFFF12CH | PIC12    | PIF12    | PMK12          | 0     | PPR122    | PPR121    | PPR120    | INTP12                         |
| FFFFF12EH | TSOOVIC  | TS00VIF  | <b>TS0OVMK</b> | 0     | TS00VPR2  | TS00VPR1  | TS0OVPR0  | INTTSOOV                       |
| FFFFF130H | TS0CCIC0 | TS0CCIF0 | TS0CCMK0       | 0     | TS0CCPR02 | TS0CCPR01 | TS0CCPR00 | INTTSOCCO                      |
| FFFFF132H | TS0CCIC1 | TS0CCIF1 | TS0CCMK1       | 0     | TS0CCPR12 | TS0CCPR11 | TS0CCPR10 | INTTSOCC1                      |
| FFFFF134H | TS0CCIC2 | TS0CCIF2 | TS0CCMK2       | 0     | TS0CCPR22 | TS0CCPR21 | TS0CCPR20 | INTTS0CC2                      |
| FFFFF136H | TS0CCIC3 | TS0CCIF3 | TS0CCMK3       | 0     | TS0CCPR32 | TS0CCPR31 | TS0CCPR30 | INTTS0CC3                      |
| FFFFF138H | TS0CCIC4 | TS0CCIF4 | TS0CCMK4       | 0     | TS0CCPR42 | TS0CCPR41 | TS0CCPR40 | INTTS0CC4                      |
| FFFFF13AH | TS0CCIC5 | TS0CCIF5 | TS0CCMK5       | 0     | TS0CCPR52 | TS0CCPR51 | TS0CCPR50 | INTTS0CC5                      |
| FFFFF13CH | TS0CDIC0 | TS0CDIF0 | TSOCDMKO       | 0     | TS0CDPR02 | TS0CDPR01 | TS0CDPR00 | INTTSOCDO                      |
| FFFFF13EH | TS0ODIC  | TS00DIF  | TS00DMK        | 0     | TS00DPR2  | TS00DPR1  | TS00DPR0  | INTTSOOD                       |
| FFFFF140H | TS0ERIC  | TS0ERIF  | <b>TS0ERMK</b> | 0     | TS0ERPR2  | TS0ERPR1  | TS0ERPR0  | INTTSOER                       |
| FFFFF142H | TSOWNIC  | TSOWNIF  | TSOWNMK        | 0     | TS0WNPR2  | TS0WNPR1  | TS0WNPR0  | INTTSOWN                       |
| FFFFF144H | TS10VIC  | TS10VIF  | TS10VMK        | 0     | TS10VPR2  | TS10VPR1  | TS1OVPR0  | INTTS10V                       |
| FFFFF146H | TS1CCIC0 | TS1CCIF0 | TS1CCMK0       | 0     | TS1CCPR02 | TS1CCPR01 | TS1CCPR00 | INTTS1CC0                      |
| FFFFF148H | TS1CCIC1 | TS1CCIF1 | TS1CCMK1       | 0     | TS1CCPR12 | TS1CCPR11 | TS1CCPR10 | INTTS1CC1                      |
| FFFFF14AH | TS1CCIC2 | TS1CCIF2 | TS1CCMK2       | 0     | TS1CCPR22 | TS1CCPR21 | TS1CCPR20 | INTTS1CC2                      |
| FFFFF14CH | TS1CCIC3 | TS1CCIF3 | TS1CCMK3       | 0     | TS1CCPR32 | TS1CCPR31 | TS1CCPR30 | INTTS1CC3                      |
| FFFFF14EH | TS1CCIC4 | TS1CCIF4 | TS1CCMK4       | 0     | TS1CCPR42 | TS1CCPR41 | TS1CCPR40 | INTTS1CC4                      |
| FFFFF150H | TS1CCIC5 | TS1CCIF5 | TS1CCMK5       | 0     | TS1CCPR52 | TS1CCPR51 | TS1CCPR50 | INTTS1CC5                      |
| FFFFF152H | TS1CDIC0 | TS1CDIF0 | TS1CDMK0       | 0     | TS1CDPR02 | TS1CDPR01 | TS1CDPR00 | INTTS1CD0                      |
| FFFFF154H | TS10DIC  | TS10DIF  | TS10DMK        | 0     | TS10DPR2  | TS10DPR1  | TS10DPR0  | INTTS10D                       |
| FFFFF156H | TS1ERIC  | TS1ERIF  | TS1ERMK        | 0     | TS1ERPR2  | TS1ERPR1  | TS1ERPR0  | INTTS1ER                       |
| FFFFF158H | TS1WNIC  | TS1WNIF  | TS1WNMK        | 0     | TS1WNPR2  | TS1WNPR1  | TS1WNPR0  | INTTS1WN                       |
| FFFFF15AH | TTOOVIC  | TT00VIF  | TT0OVMK        | 0     | TT00VPR2  | TT00VPR1  | TT0OVPR0  | INTTTOOV                       |

## Table 4-4 Addresses and bits of interrupt control registers (1/3)



|           |           |           |           |       | Bit        |            |            | Associated         |
|-----------|-----------|-----------|-----------|-------|------------|------------|------------|--------------------|
| Address   | Register  | 7         | 6         | 5 - 3 | 2          | 1          | 0          | interrupt          |
| FFFFF15CH | TTOCCICO  | TTOCCIFO  | ТТОССМКО  | 0     | TT0CCPR02  | TT0CCPR01  | TT0CCPR00  | INTTTOCCO          |
| FFFFF15EH | TT0CCIC1  | TT0CCIF1  | TT0CCMK1  | 0     | TT0CCPR12  | TT0CCPR11  | TT0CCPR10  | INTTT0CC1          |
| FFFFF160H | TTOECIC   | TTOECIF   | TT0ECMK   | 0     | TT0ECPR2   | TT0ECPR1   | TT0ECPR0   | INTTT0EC           |
| FFFFF162H | TT10VIC   | TT10VIF   | TT10VMK   | 0     | TT10VPR2   | TT10VPR1   | TT1OVPR0   | INTTT10V           |
| FFFFF164H | TT1CCIC0  | TT1CCIF0  | TT1CCMK0  | 0     | TT1CCPR02  | TT1CCPR01  | TT1CCPR00  | INTT1CC0           |
| FFFFF166H | TT1CCIC1  | TT1CCIF1  | TT1CCMK1  | 0     | TT1CCPR12  | TT1CCPR11  | TT1CCPR10  | INTTT1CC1          |
| FFFFF168H | TT1ECIC   | TT1ECIF   | TT1ECMK   | 0     | TT1ECPR2   | TT1ECPR1   | TT1ECPR0   | INTTT1EC           |
| FFFFF16AH | TAA0OVIC  | TAA0OVIF  | TAA0OVMK  | 0     | TAA0OVPR2  | TAA0OVPR1  | TAA0OVPR0  | INTTAA0OV          |
| FFFFF16CH | TAA0CCIC0 | TAA0CCIF0 | ТААОССМКО | 0     | TAA0CCPR02 | TAA0CCPR01 | TAA0CCPR00 | INTTAA0CC0         |
| FFFFF16EH | TAA0CCIC1 | TAA0CCIF1 | TAA0CCMK1 | 0     | TAA0CCPR12 | TAA0CCPR11 | TAA0CCPR10 | INTTAA0CC1         |
| FFFFF170H | TAA1OVIC  | TAA10VIF  | TAA1OVMK  | 0     | TAA1OVPR2  | TAA1OVPR1  | TAA1OVPR0  | INTTAA10V          |
| FFFFF172H | TAA1CCIC0 | TAA1CCIF0 | TAA1CCMK0 | 0     | TAA1CCPR02 | TAA1CCPR01 | TAA1CCPR00 | INTTAA1CC0         |
| FFFFF174H | TAA1CCIC1 | TAA1CCIF1 | TAA1CCMK1 | 0     | TAA1CCPR12 | TAA1CCPR11 | TAA1CCPR10 | INTTAA1CC1         |
| FFFFF176H | TAA2OVIC  | TAA2OVIF  | TAA2OVMK  | 0     | TAA2OVPR2  | TAA2OVPR1  | TAA2OVPR0  | INTTAA2OV          |
| FFFFF178H | TAA2CCIC0 | TAA2CCIF0 | TAA2CCMK0 | 0     | TAA2CCPR02 | TAA2CCPR01 | TAA2CCPR00 | INTTAA2CC0         |
| FFFFF17AH | TAA2CCIC1 | TAA2CCIF1 | TAA2CCMK1 | 0     | TAA2CCPR12 | TAA2CCPR11 | TAA2CCPR10 | INTTAA2CC1         |
| FFFFF17CH | TAA3OVIC  | TAA3OVIF  | TAA3OVMK  | 0     | TAA3OVPR2  | TAA3OVPR1  | TAA3OVPR0  | INTTAA3OV          |
| FFFFF17EH | TAA3CCIC0 | TAA3CCIF0 | TAA3CCMK0 | 0     | TAA3CCPR02 | TAA3CCPR01 | TAA3CCPR00 | INTTAA3CC0         |
| FFFFF180H | TAA3CCIC1 | TAA3CCIF1 | TAA3CCMK1 | 0     | TAA3CCPR12 | TAA3CCPR11 | TAA3CCPR10 | INTTAA3CC1         |
| FFFFF182H | TAA4OVIC  | TAA4OVIF  | TAA4OVMK  | 0     | TAA4OVPR2  | TAA4OVPR1  | TAA4OVPR0  | INTTAA4OV          |
| FFFFF184H | TAA4CCIC0 | TAA4CCIF0 | TAA4CCMK0 | 0     | TAA4CCPR02 | TAA4CCPR01 | TAA4CCPR00 | INTTAA4CC0         |
| FFFFF186H | TAA4CCIC1 | TAA4CCIF1 | TAA4CCMK1 | 0     | TAA4CCPR12 | TAA4CCPR11 | TAA4CCPR10 | INTTAA4CC1         |
| FFFFF188H | TAA5OVIC  | TAA5OVIF  | TAA5OVMK  | 0     | TAA5OVPR2  | TAA5OVPR1  | TAA5OVPR0  | INTTAA5OV          |
| FFFFF18AH | TAA5CCIC0 | TAA5CCIF0 | TAA5CCMK0 | 0     | TAA5CCPR02 | TAA5CCPR01 | TAA5CCPR00 | INTTAA5CC0         |
| FFFFF18CH | TAA5CCIC1 | TAA5CCIF1 | TAA5CCMK1 | 0     | TAA5CCPR12 | TAA5CCPR11 | TAA5CCPR10 | INTTAA5CC1         |
| FFFFF18EH | TAA6OVIC  | TAA6OVIF  | TAA6OVMK  | 0     | TAA6OVPR2  | TAA6OVPR1  | TAA6OVPR0  | INTTAA6OV          |
| FFFFF190H | TAA6CCIC0 | TAA6CCIF0 | TAA6CCMK0 | 0     | TAA6CCPR02 | TAA6CCPR01 | TAA6CCPR00 | INTTAA6CC0         |
| FFFFF192H | TAA6CCIC1 | TAA6CCIF1 | TAA6CCMK1 | 0     | TAA6CCPR12 | TAA6CCPR11 | TAA6CCPR10 | INTTAA6CC1         |
| FFFFF194H | TAA7OVIC  | TAA7OVIF  | TAA7OVMK  | 0     | TAA7OVPR2  | TAA7OVPR1  | TAA7OVPR0  | INTTAA7OV          |
| FFFFF196H | TAA7CCIC0 | TAA7CCIF0 | ТАА7ССМК0 | 0     | TAA7CCPR02 | TAA7CCPR01 | TAA7CCPR00 | INTTAA7CC0         |
| FFFFF198H | TAA7CCIC1 | TAA7CCIF1 | TAA7CCMK1 | 0     | TAA7CCPR12 | TAA7CCPR11 | TAA7CCPR10 | INTTAA7CC1         |
| FFFFF19AH | TAA8OVIC  | TAA8OVIF  | TAA8OVMK  | 0     | TAA8OVPR2  | TAA8OVPR1  | TAA8OVPR0  | INTTAA8OV          |
| FFFFF19CH | TAA8CCIC0 | TAA8CCIF0 | TAA8CCMK0 | 0     | TAA8CCPR02 | TAA8CCPR01 | TAA8CCPR00 | INTTAA8CC0         |
| FFFFF19EH | TAA8CCIC1 | TAA8CCIF1 | TAA8CCMK1 | 0     | TAA8CCPR12 | TAA8CCPR11 | TAA8CCPR10 | INTTAA8CC1         |
| FFFFF1A0H | TAA9OVIC  | TAA9OVIF  | TAA9OVMK  | 0     | TAA9OVPR2  | TAA9OVPR1  | TAA9OVPR0  | INTTAA9OV          |
| FFFFF1A2H | TAA9CCIC0 | TAA9CCIF0 | TAA9CCMK0 | 0     | TAA9CCPR02 | TAA9CCPR01 | TAA9CCPR00 | INTTAA9CC0         |
| FFFFF1A4H | TAA9CCIC1 | TAA9CCIF1 | TAA9CCMK1 | 0     | TAA9CCPR12 | TAA9CCPR11 | TAA9CCPR10 | INTTAA9CC1         |
| FFFFF1A6H | BRGIC     | BRGIF     | BRGMK     | 0     | BRGPR2     | BRGPR1     | BRGPR0     | INTBRG0<br>INTBRG1 |
| FFFFF1A8H | BRGIC2    | BRGIF2    | BRGMK2    | 0     | BRGPR22    | BRGPR21    | BRGPR20    | INTBRG2            |
| FFFFF1B6H | COERRIC   | COERRIF   | C0ERRMK   | 0     | C0ERRPR2   | C0ERRPR1   | C0ERRPR0   | INTC0ERR           |

### Table 4-4 Addresses and bits of interrupt control registers (2/3)



| Address   | Deviator |         |         |       | Bit      |          |          | Associated       |
|-----------|----------|---------|---------|-------|----------|----------|----------|------------------|
| Address   | Register | 7       | 6       | 5 - 3 | 2        | 1        | 0        | interrupt        |
| FFFFF1B8H | COWUPIC  | COWUPIF | COWUPMK | 0     | COWUPPR2 | COWUPPR1 | COWUPPRO | INTCOWUP         |
| FFFFF1BAH | CORECIC  | CORECIF | CORECMK | 0     | CORECPR2 | CORECPR1 | CORECPR0 | INTCOREC         |
| FFFFF1BCH | COTRXIC  | COTRXIF | COTRXMK | 0     | C0TRXPR2 | C0TRXPR1 | C0TRXPR0 | INTCOTRX         |
| FFFFF1BEH | C1ERRIC  | C1ERRIF | C1ERRMK | 0     | C1ERRPR2 | C1ERRPR1 | C1ERRPR0 | INTC1ERR         |
| FFFFF1C0H | C1WUPIC  | C1WUPIF | C1WUPMK | 0     | C1WUPPR2 | C1WUPPR1 | C1WUPPR0 | INTC1WUP         |
| FFFFF1C2H | C1RECIC  | C1RECIF | C1RECMK | 0     | C1RECPR2 | C1RECPR1 | C1RECPR0 | INTC1REC         |
| FFFFF1C4H | C1TRXIC  | C1TRXIF | C1TRXMK | 0     | C1TRXPR2 | C1TRXPR1 | C1TRXPR0 | INTC1TRX         |
| FFFFF1D6H | CBOTIC   | CB0TIF  | CBOTMK  | 0     | CB0TPR2  | CB0TPR1  | CBOTPRO  | INTCBOT          |
| FFFFF1D8H | CBORIC   | CBORIF  | CBORMK  | 0     | CB0RPR2  | CB0RPR1  | CBORPRO  | INTCBOR          |
| FFFFF1DAH | CBOREIC  | CBOREIF | CBOREMK | 0     | CB0REPR2 | CB0REPR1 | CB0REPR0 | INTCBORE         |
| FFFFF1DCH | CB1TIC   | CB1TIF  | CB1TMK  | 0     | CB1TPR2  | CB1TPR1  | CB1TPR0  | INTCB1T          |
| FFFFF1DEH | CB1RIC   | CB1RIF  | CB1RMK  | 0     | CB1RPR2  | CB1RPR1  | CB1RPR0  | INTCB1R          |
| FFFFF1E0H | CB1REIC  | CB1REIF | CB1REMK | 0     | CB1REPR2 | CB1REPR1 | CB1REPR0 | INTCB1RE         |
| FFFFF1E2H | CE00FIC  | CE00FIF | CE00FMK | 0     | CE00FPR2 | CE00FPR1 | CE00FPR0 | INTCE00F         |
| FFFFF1E4H | CEOCIC   | CE0CIF  | CEOCMK  | 0     | CE0CPR2  | CE0CPR1  | CE0CPR0  | INTCE0C          |
| FFFFF1E6H | CE10FIC  | CE10FIF | CE10FMK | 0     | CE10FPR2 | CE10FPR1 | CE10FPR0 | INTCE10F         |
| FFFFF1E8H | CE1CIC   | CE1CIF  | CE1CMK  | 0     | CE1CPR2  | CE1CPR1  | CE1CPR0  | INTCE1C          |
| FFFFF1EAH | UCOREIC  | UCOREIF | UCOREMK | 0     | UC0REPR2 | UC0REPR1 | UC0REPR0 | INTUCORE         |
| FFFFF1ECH | UCOTIC   | UCOTIF  | UCOTMK  | 0     | UC0TPR2  | UC0TPR1  | UC0TPR0  | INTUCOT          |
| FFFFF1EEH | UC1REIC  | UC1REIF | UC1REMK | 0     | UC1REPR2 | UC1REPR1 | UC1REPR0 | INTUC1RE         |
| FFFFF1F0H | UC1TIC   | UC1TIF  | UC1TMK  | 0     | UC1TPR2  | UC1TPR1  | UC1TPR0  | INTUC1T          |
| FFFFF1F2H | ADICO    | ADIF0   | ADMK0   | 0     | ADPR02   | ADPR01   | ADPR00   | INTAD0           |
| FFFFF1F4H | ADIC1    | ADIF1   | ADMK1   | 0     | ADPR12   | ADPR11   | ADPR10   | INTAD1           |
| FFFFF1F6H | DMAIC2   | DMAIF2  | DMAMK2  | 0     | DMAPR22  | DMAPR21  | DMAPR20  | INTDMA2          |
| FFFFF1F8H | DMAIC3   | DMAIF3  | DMAMK3  | 0     | DMAPR32  | DMAPR31  | DMAPR30  | INTDMA3<br>INTFL |

#### Table 4-4 Addresses and bits of interrupt control registers (3/3)

### 4.3.5 IMR0 to IMR7 - Interrupt mask registers

These registers set the interrupt mask state for the maskable interrupts.

The IMKn bit of the IMRm (m = 0 to 7) registers is equivalent to the xxMK bit of the xxIC register.

IMRm registers can be read/written in 16- bit, 8-bit, and 1-bit units.

The address of the lower 8-bit register IMRmL is equal to that of the 16-bit IMRm register, and the higher 8-bit register IMRmH can be accessed on the following address (address (IMRm) + 1).

Caution

- 1. Mask bits, indicated with "0", must not be altered. Make sure to set them "0"
  - 2. Mask bits, indicated with "1", must not be altered. Make sure to set them "1" when writing to the register.



|       | 15             | 14              | 13              | 12             | 11              | 10              | 9               | 8              | Address              | Initial value          |
|-------|----------------|-----------------|-----------------|----------------|-----------------|-----------------|-----------------|----------------|----------------------|------------------------|
| IMR0  | <b>TS0OVMK</b> | PMK12           | PMK11           | PMK10          | PMK9            | PMK8            | PMK7            | PMK6           | FFFFF100H            | FFFFH                  |
|       | 7              | 6               | 5               | 4              | 3               | 2               | 1               | 0              |                      |                        |
|       | PMK5           | PMK4            | PMK3            | PMK2           | PMK1            | PMK0            | OSDMK           | ERRMK          |                      |                        |
|       |                |                 | 10              | 10             |                 |                 |                 |                |                      |                        |
| IMR1  | 15<br>TS1CCMK4 | 14<br>TS1CCMK3  | 13<br>TS1CCMK2  | 12<br>TS1CCMK1 | 11<br>TS1CCMK0  | 10<br>TS1OVMK   | 9<br>TSOWNMK    | 8<br>TS0ERMK   | Address<br>FFFFF102H | Initial value<br>FFFFH |
|       | Ļ              |                 |                 |                |                 |                 |                 |                | 1111110211           |                        |
|       | 7<br>TSOODMK   | 6<br>TSOCDMK0   | 5<br>TSOCCMK5   | 4<br>TSOCCMK4  | 3<br>ТSOCCMK3   | 2<br>TSOCCMK2   | 1<br>TSOCCMK1   | 0<br>TSOCCMK0  |                      |                        |
|       | TSUODINK       | 1 SUCDIVIKU     | 1 SUCCIVINS     | 130000014      | 10000           | 1 3000 WIKZ     | 1 SUCCIMIN I    | 1 SOCCIVINO    |                      |                        |
|       | 15             | 14              | 13              | 12             | 11              | 10              | 9               | 8              | Address              | Initial value          |
| IMR2  | TTA0CCMK1      | TTAOCCMKO       | TTAOOVMK        | TT1ECMK        | TT1CCMK1        | TT1CCMK0        | TT10VMK         | TTOECMK        | FFFFF104H            | FFFFH                  |
|       | 7              | 6               | 5               | 4              | 3               | 2               | 1               | 0              |                      |                        |
|       | TT0CCMK1       | TTOCCMKO        | TTOOVMK         | TS1WNMK        | TS1ERMK         | TS10DMK         | TS1CDMK0        | TS1CCMK5       |                      |                        |
|       |                |                 |                 |                |                 |                 |                 |                |                      |                        |
| IMR3  | 15<br>TTA6OVMK | 14<br>TTA5CCMK1 | 13<br>TTA5CCMK0 | 12<br>TTA5OVMK | 11<br>TTA4CCMK1 | 10<br>TTA4CCMK0 | 9<br>TTA 40V/MK | 8<br>TTA3CCMK1 | Address<br>FFFFF106H | Initial value          |
| נחווו |                |                 |                 |                |                 |                 |                 |                | FFFFIVON             | FFFFH                  |
|       | 7              | 6               | 5               | 4              | 3               | 2               | 1               |                |                      |                        |
|       | TTA3CCMK0      | TTA3OVMK        | TTA2CCMK1       | TTA2CCMK0      | I TA2OVMK       | TTA1CCMK1       | TIATCOMKO       | TIATOVMK       |                      |                        |
|       | 15             | 14              | 13              | 12             | 11              | 10              | 9               | 8              | Address              | Initial value          |
| IMR4  | 1              | 1               | 1               | BRGMK2         | BRGMK           | TTA9CCMK1       | ТТА9ССМКО       | TTA9OVMK       | FFFFF108H            | FFFFH                  |
|       | 7              | 6               | 5               | 4              | 3               | 2               | 1               | 0              |                      |                        |
|       | TTA8CCMK1      | TTA8CCMK0       | TTA8OVMK        | TTA7CCMK1      | TTA7CCMK0       | TTA7OVMK        | TTA6CCMK1       | TTA6CCMK0      |                      |                        |
|       |                |                 |                 |                |                 |                 |                 |                |                      |                        |
|       | 15             | 14              | 13              | 12             | 11              | 10              | 9               | 8              | Address              | Initial value          |
| IMR5  | 1              | 1               | 1               | 1              | 1               | CITRXMK         | CIRECMK         | C1WUPMK        | FFFFF10AH            | FFFFH                  |
|       | 7              | 6               | 5               | 4              | 3               | 2               | 1               | 0              |                      |                        |
|       | CIERRMK        | CUIRXMK         | CORECMK         | COWUPMK        | CUERRMK         | 1               | 1               | 1              |                      |                        |
|       | 15             | 14              | 13              | 12             | 11              | 10              | 9               | 8              | Address              | Initial value          |
| IMR6  | UC1REMK        | UCOTMK          | UC0REMK         | CE1CMK         | CE10FMK         | CE0CMK          | CE00FMK         | CB1REMK        | FFFFF10CH            | FFFFH                  |
|       | 7              | 6               | 5               | 4              | 3               | 2               | 1               | 0              |                      |                        |
|       | CB1RMK         | CB1TMK          | CBOREMK         | CBORMK         | CBOTMK          | 1               | 1               | 1              |                      |                        |
|       | -              |                 | •               | •              | •               |                 |                 | ·              |                      |                        |
|       | 15             | 14              | 13              | 12             | 11              | 10              | 9               | 8              | Address              | Initial value          |
| IMR7  | 0              | 0               | 0               | 0              | 0               | 0               | 0               | 0              | FFFFF10EH            | 001FH                  |
|       | 7              | 6               | 5               | 4              | 3               | 2               | 1               | 0              |                      |                        |
|       | 0              | 0               | 0               | DMAMK3         | DMAMK2          | ADMK1           | ADMK0           | UC1TMK         |                      |                        |

RENESAS

| I | Bit position | Bit name | Function                                                                                            |
|---|--------------|----------|-----------------------------------------------------------------------------------------------------|
|   | 15 to 0      | xxMKn    | Interrupt mask flag.<br>0: Interrupt servicing enabled<br>1: Interrupt servicing disabled (pending) |

## 4.3.6 ISPR - In-service priority register

This register holds the priority level of the maskable interrupt currently acknowledged. When an interrupt request is acknowledged, the bit of this register corresponding to the priority level of that interrupt request is set to 1 and remains set while the interrupt is serviced.

When the RETI instruction is executed, the bit corresponding to the interrupt request having the highest priority is automatically reset to 0 by hardware. However, it is not reset to 0 when execution is returned from non-maskable interrupt servicing or exception processing.

This register is read-only in 8-bit or 1-bit units.



| Bit position | Bit name          | Function                                                                                                                                                             |
|--------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 to 0       | ISPR7 to<br>ISPR0 | Indicates priority of interrupt currently acknowledged<br>0: Interrupt request with priority n not acknowledged<br>1: Interrupt request with priority n acknowledged |

**Note** n = 0 to 7 (priority level)



## 4.3.7 Maskable interrupt status flag (ID)

The ID flag is bit 5 of the PSW and this controls the maskable interrupt's operating state, and stores control information regarding enabling or disabling of interrupt requests.

| 31                |          | 6 5 4     |         |   |           |
|-------------------|----------|-----------|---------|---|-----------|
| PSW 0 0 0 0 0 0 0 | ) 0 NP F | EP ID SAT | CY OV S | Z | 00000020H |

| Bit position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5            | ID       | Indicates whether maskable interrupt processing is enabled or disabled.<br>0: Maskable interrupt request acknowledgement enabled<br>1: Maskable interrupt request acknowledgement disabled (pending)<br>This bit is set to 1 by the DI instruction and reset to 0 by the EI instruction. Its value<br>is also modified by the RETI instruction or LDSR instruction when referencing to<br>PSW.<br>Non-maskable interrupt requests and exceptions are acknowledged regardless of<br>this flag. when a maskable interrupt is acknowledged, the ID flag is automatically<br>set to 1 by hardware.<br>The interrupt request generated during the acknowledgement disabled period<br>(ID = 1) is acknowledged when the PIFn bit of PICn register is set to 1, and the ID<br>flag is reset to 0. |

## 4.3.8 External maskable interrupts

This microcontroller provides 13 maskable external interrupts INTP0 to INTP12 with the following features:

- Analog input filter (refer to "Analog filtered inputs" on page 63)
- Interrupt detection selectable for each interrupt input:
  - Rising edge
  - Falling edge
  - Both edges: rising and falling edge
- Wakeup capability from stand-by mode of INTPn upon
  - Rising edge
  - Falling edge
  - Both edges: rising and falling edge

For configuration of the external interrupt events refer to *"Edge and Level Detection Configuration" on page 124.* 



## 4.4 Edge and Level Detection Configuration

The registers for the configuration of interrupts specify, whether an interrupt is detected at the falling, rising, or on both falling and rising edge of the signal. For every maskable or non-maskable interrupt two bits define the type of edge:

#### Table 4-5 Edge specification of interrupts

| ESN1 | ESN0            | Function                    |                         |  |  |  |
|------|-----------------|-----------------------------|-------------------------|--|--|--|
|      | INTP0 to INTP12 | NMI                         |                         |  |  |  |
| 0    | 0               | falling edge                | falling edge            |  |  |  |
| 0    | 1               | rising edge                 | rising edge             |  |  |  |
| 1    | 0               | disabled (no INT generated) | Setting prohibited      |  |  |  |
| 1    | 1               | falling and rising edge     | falling and rising edge |  |  |  |

#### (1) INTM0 - External interrupt edge specification register

The 8-bit INTM0 register specifies the edge at which an interrupt is detected. This register concerns the pins NMI and INTP0 to INTP2.

Access This register can be read/written in 8-bit units.

Address FFFF F880<sub>H</sub>

Initial Value 00<sub>H</sub>. This register is initialized by RESET.

|   | 7     | 6    | 5    | 4    | 3    | 2               | 1    | 0    |
|---|-------|------|------|------|------|-----------------|------|------|
|   | ES21  | ES20 | ES11 | ES10 | ES01 | ES00            | ESN1 | ESN0 |
|   | R/W   | R/W  | R/W  | R/W  | R/W  | R/W             | R/W  | R/W  |
| ſ | INTP2 |      | INT  | TP1  | INT  | <sup>-</sup> P0 | N    | MI   |

#### Table 4-6 INTM0 register contents

| Bit position | Bit name | Function                                        |
|--------------|----------|-------------------------------------------------|
| 7            | ES21     | Specifies the edge detection at terminal INTP2. |
| 6            | ES20     | See Table 4-5 on page 124.                      |
| 5            | ES11     | Specifies the edge detection at terminal INTP1. |
| 4            | ES10     | See Table 4-5 on page 124.                      |
| 3            | ES01     | Specifies the edge detection at terminal INTP0. |
| 2            | ES00     | See Table 4-5 on page 124.                      |
| 1            | ESN1     | Specifies the edge detection at terminal NMI.   |
| 0            | ESN0     | See Table 4-5 on page 124.                      |



#### (2) INTM1 - External interrupt edge specification register

The 8-bit INTM1 register specifies the edge at which an interrupt is detected. This register concerns the pins INTP3 to INTP6.

Access This register can be read/written in 8-bit units.

Address FFFF F882<sub>H</sub>

**Initial Value**  $00_{H}$ . This register is initialized by RESET.

| - | 7     | 6    | 5     | 4    | 3     | 2    | 1    | 0    |
|---|-------|------|-------|------|-------|------|------|------|
|   | ES61  | ES60 | ES51  | ES50 | ES41  | ES40 | ES31 | ES30 |
|   | R/W   | R/W  | R/W   | R/W  | R/W   | R/W  | R/W  | R/W  |
|   | INTP6 |      | INTP5 |      | INTP4 |      | INT3 |      |

#### Table 4-7 INTM1 register contents

| Bit position | Bit name | Function                                        |
|--------------|----------|-------------------------------------------------|
| 7            | ES61     | Specifies the edge detection at terminal INTP6. |
| 6            | ES60     | See Table 4-5 on page 124.                      |
| 5            | ES51     | Specifies the edge detection at terminal INTP5. |
| 4            | ES50     | See Table 4-5 on page 124.                      |
| 3            | ES41     | Specifies the edge detection at terminal INTP4. |
| 2            | ES40     | See Table 4-5 on page 124.                      |
| 1            | ES31     | Specifies the edge detection at terminal INTP3. |
| 0            | ES30     | See Table 4-5 on page 124.                      |



#### (3) INTM2 - External interrupt edge specification register

The 8-bit INTM2 register specifies the edge at which an interrupt is detected. This register concerns the pins INTP7 to INTP10.

Access This register can be read/written in 8-bit units.

Address FFFF F884<sub>H</sub>

Initial Value 00<sub>H</sub>. This register is initialized by RESET.

| 7      | 6     | 5    | 4     | 3    | 2     | 1    | 0     |  |
|--------|-------|------|-------|------|-------|------|-------|--|
| ES101  | ES100 | ES91 | ES90  | ES81 | ES80  | ES71 | ES70  |  |
| R/W    | R/W   | R/W  | R/W   | R/W  | R/W   | R/W  | R/W   |  |
| INTP10 |       | INT  | INTP9 |      | INTP8 |      | INTP7 |  |

#### Table 4-8 INTM2 register contents

| Bit position | Bit name | Function                                         |
|--------------|----------|--------------------------------------------------|
| 7            | ES101    | Specifies the edge detection at terminal INTP10. |
| 6            | ES100    | See Table 4-5 on page 124.                       |
| 5            | ES91     | Specifies the edge detection at terminal INTP9.  |
| 4            | ES90     | See Table 4-5 on page 124.                       |
| 3            | ES81     | Specifies the edge detection at terminal INTP8.  |
| 2            | ES80     | See Table 4-5 on page 124.                       |
| 1            | ES71     | Specifies the edge detection at terminal INTP7.  |
| 0            | ES70     | See Table 4-5 on page 124.                       |

#### (4) INTM3 - External interrupt edge specification register

The 8-bit INTM3 register specifies the edge at which an interrupt is detected. This register concerns the pins INTP11 to INTP12.

Access This register can be read/written in 8-bit units.

Address FFFF F886<sub>H</sub>

Initial Value 00<sub>H</sub>. This register is initialized by RESET.

| _ | 7   | 6   | 5   | 4   | 3     | 2     | 1     | 0     |
|---|-----|-----|-----|-----|-------|-------|-------|-------|
|   | 0   | 0   | 0   | 0   | ES121 | ES120 | ES111 | ES110 |
|   | R/W | R/W | R/W | R/W | R/W   | R/W   | R/W   | R/W   |
|   |     |     |     |     | INT   | P12   | INT   | P11   |

#### Table 4-9 INTM3 register contents

| Bit position | Bit name | Function                                         |  |  |  |  |
|--------------|----------|--------------------------------------------------|--|--|--|--|
| 3            | ES121    | Specifies the edge detection at terminal INTP12. |  |  |  |  |
| 2            | ES120    | See Table 4-5 on page 124.                       |  |  |  |  |
| 1            | ES111    | Specifies the edge detection at terminal INTP11. |  |  |  |  |
| 0            | ES110    | See Table 4-5 on page 124.                       |  |  |  |  |



## 4.5 Interrupt Sharing

Interrupt sharing is supported for both non-maskable and maskable interrupts. The INTSEL register configures interrupt sharing.

Non-maskable Interrupt sharing for non-maskable interrupts can be enabled by setting bit INTSEL.ISR = 1. If interrupt sharing is enabled, the interrupt signals INTDEDF, INTDEDR, and INTOSD generate an NMI instead of a maskable interrupt.



Figure 4-10 shows the logic operations of interrupt sharing for NMI.

Figure 4-10 Interrupt sharing for NMI

Maskable interrupts

Some interrupt sources share the same maskable interrupt. There are the following options for interrupt sharing:

- Any of the interrupt sources can generate the corresponding interrupt request. All these interrupt sources are combined with logical "or".
- An interrupt selection bit defines which interrupt source can generate the corresponding interrupt request.

*Table 4-10 on page 128* lists the shared maskable interrupts and, if available, their corresponding interrupt selection bit. For more details on the interrupt sources see the interrupt/exception source list in *Table 4-1 on page 100*.



| Shared interrupts | Interrupt selection         |   | Valid interrupt sources | Interrupt source identification                                                                                                                                                        | Default<br>priority |                                                                                                                                                                                        |   |
|-------------------|-----------------------------|---|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| INTDEDF / INTDEDR | logical "or" combination    |   | INTDEDF / INTDEDR       | status flags in the interrupt source module                                                                                                                                            | 0                   |                                                                                                                                                                                        |   |
| INTP4 / INTUCOR   | logical "or"<br>combination |   | •                       |                                                                                                                                                                                        | INTP4 / INTUCOR     | INTUCOR identified by status flags in<br>UARTCO.<br>If only INTUCOR interrupts shall be served,<br>INTP4 interrupts can be suppressed by<br>setting INTM1.ES4[1:0] = 10 <sub>B</sub> . | 6 |
| INTP5 / INTUC1R   | logical "or"<br>combination |   | INTP5 / INTUC1R         | INTUC1R identified by status flags in<br>UARTC1.<br>If only INTUC1R interrupts shall be served,<br>INTP5 interrupts can be suppressed by<br>setting INTM1.ES5[1:0] = 10 <sub>B</sub> . | 7                   |                                                                                                                                                                                        |   |
| INTBRG0 / INTBRG1 | INTSEL.BRGSSR 0             |   | INTBRG0                 | determined by INTSEL.BRGSSR                                                                                                                                                            | 75                  |                                                                                                                                                                                        |   |
|                   |                             | 1 | INTBRG1                 |                                                                                                                                                                                        |                     |                                                                                                                                                                                        |   |
| INTDMA3           | INTSEL.INTSEL4 0            |   | INTDMA3                 | -                                                                                                                                                                                      | 116                 |                                                                                                                                                                                        |   |

 Table 4-10
 Shared maskable interrupts



#### (1) INTSEL - Interrupt share enable register

The 8-bit INTSEL register specifies

- which interrupt source generates a maskable interrupt with priorities 75, 116
- whether or not the interrupt source for the NMI is shared

Access This register can be read/written in 8-bit and 1-bit units.

Address FFFF F6D0<sub>H</sub>

Initial Value 00<sub>H</sub>. This register is initialized by RESET.

| 7   | 6 | 5 | 4       | 3 | 2 | 1 | 0      |
|-----|---|---|---------|---|---|---|--------|
| ISR | 0 | 0 | INTSEL4 | 0 | 0 | 0 | BRGSSR |
| R/W | R | R | R/W     | R | R | R | R/W    |

#### Table 4-11 INTSEL register contents

| Bit position | Bit name | Function                                                                                                                       |  |  |  |
|--------------|----------|--------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|              |          | Enables/disables sharing of NMI<br>0: NMI sharing disabled<br>1: NMI sharing enabled                                           |  |  |  |
| 7            | 7 ISR    | Caution: ISR can only be changed once after reset.<br>Thus the NMI can be enabled after reset,<br>but not disabled afterwards. |  |  |  |
| 4            | INTSEL4  | Maskable interrupt with priority 116 is generated by<br>0: INTDMA3<br>1: reserved                                              |  |  |  |
| 0            | BRGSSR   | Maskable interrupt with priority 75 is generated by<br>0: INTBRG0<br>1: INTBRG1                                                |  |  |  |

**Caution** Before changing any interrupt selection bit in this register the related interrupt sources must be disabled. Otherwise unrelated interrupt requests may occur.



#### (2) INTERRF - Interrupt source flag register

The 8-bit INTTERRF register identifies the interrupt source of NMI and INTO (default priority 0) interrupts.

Access This register can be read/written in 8-bit and 1-bit units.

Address FFFF F6D2<sub>H</sub>

Initial Value 00<sub>H</sub>. This register is initialized by RESET.

| 7       | 6   | 5   | 4   | 3   | 2   | 1       | 0       |
|---------|-----|-----|-----|-----|-----|---------|---------|
| INTERR7 | 0   | 0   | 0   | 0   | 0   | INTERR1 | INTERR0 |
| R/W     | R/W | R/W | R/W | R/W | R/W | R/W     | R/W     |

#### Table 4-12 INTTERF register contents

| Bit position | Bit name | Function                                                                                                           |
|--------------|----------|--------------------------------------------------------------------------------------------------------------------|
| 7            | INTERR7  | Displays the status of interrupt INTOSD (Clock<br>Monitor)<br>0: Interrupt not generated<br>1: Interrupt generated |
| 1            | INTERR1  | Displays the status of interrupt INTDEDR (RAM)<br>0: Interrupt not generated<br>1: Interrupt generated             |
| 0            | INTERR0  | Displays the status of interrupt INTDEDF (Flash)<br>0: Interrupt not generated<br>1: Interrupt generated           |

**Note 1.** After the CPU has processed the associated interrupt routine, the related flag in the INTERRF register must be reset to '0' by a bit manipulation instruction. If a further interrupt occurs while the associated bit in the register is reset, the new interrupt request will also be discarded.

2. Writing to ROMEAD register is prohibited while INTERR0 bit is "1". Writing to RAMEAD register is prohibited while INTERR1 bit is "1".



## 4.6 Software Exception

## 4.6.1 Operation

If a software exception occurs, the CPU performs the following processing, and transfers control to the handler routine:

- 1. Saves the restored PC to EIPC.
- 2. Saves the current PSW to EIPSW.
- 3. Writes an exception code to the lower 16 bits (EICC) of ECR (interrupt source).
- 4. Sets the EP and ID bits of the PSW.
- 5. Sets the handler address (00000040H or 00000050H) corresponding to the software exception to the PC, and transfers control.

Figure 4-11 illustrates the processing of a software exception.



#### Figure 4-11 Software exception processing

Note TRAP Instruction Format: TRAP vector (the vector is a value from 0 to 1FH.)

The handler address is determined by the TRAP instruction's operand (vector). If the vector is 0 to 0FH, it becomes 00000040H, and if the vector is 10H to 1FH, it becomes 00000050H.



## 4.6.2 Restore

Recovery from software exception processing is carried out by the RETI instruction.

By executing the RETI instruction, the CPU carries out the following processing and shifts control to the restored PC's address.

- 1. Loads the restored PC and PSW from EIPC and EIPSW because the EP bit of the PSW is 1.
- 2. Transfers control to the address of the restored PC and PSW.

*Figure 4-12* illustrates the processing of the RETI instruction.



Figure 4-12 RETI instruction processing

**Caution** When the PSW.EP bit and the PSW.NP bit are changed by the LDSR instruction during the software exception processing, in order to restore the PC and PSW correctly during recovery by the RETI instruction, it is necessary to set PSW.EP back to 1 using the LDSR instruction immediately before the RETI instruction.

Note The solid lines show the CPU processing flow.



## 4.6.3 Exception status flag (EP)

The EP flag is bit 6 of PSW, and is a status flag used to indicate that exception processing is in progress. It is set when an exception occurs.

|     | 31 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   | 8 | 7  | 6  | 5  | 4   | 3  | 2  | 1 | 0 | Initial value |
|-----|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|----|----|----|-----|----|----|---|---|---------------|
| PSW | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | NP | EP | ID | SAT | CY | OV | S | Z | 00000020H     |

| Bit position | Bit name | Function                                                                                                                            |
|--------------|----------|-------------------------------------------------------------------------------------------------------------------------------------|
| 6            | EP       | Shows that exception processing is in progress.<br>0: Exception processing not in progress.<br>1: Exception processing in progress. |



## 4.7 Exception Trap

An exception trap is an interrupt that is requested when an illegal execution of an instruction takes place. For this microcontroller, an illegal opcode exception (ILGOP: Illegal Opcode Trap) is considered as an exception trap.

## 4.7.1 Illegal opcode definition

The illegal instruction has an opcode (bits 10 to 5) of 111111B, a sub-opcode (bits 23 to 26) of 0111B to 1111B, and a sub-opcode (bit 16) of 0B. An exception trap is generated when an instruction applicable to this illegal instruction is executed.



Note ×: Arbitrary

### (1) Operation

If an exception trap occurs, the CPU performs the following processing, and transfers control to the handler routine:

- 1. Saves the restored PC to DBPC.
- 2. Saves the current PSW to DBPSW.
- 3. Sets the NP, EP, and ID bits of the PSW.
- 4. Sets the handler address (0000060H) corresponding to the exception trap to the PC, and transfers control.

Figure 4-13 illustrates the processing of the exception trap.



Figure 4-13 Exception trap processing



#### (2) Restore

Recovery from an exception trap is carried out by the DBRET instruction. By executing the DBRET instruction, the CPU carries out the following processing and controls the address of the restored PC.

- 1. Loads the restored PC and PSW from DBPC and DBPSW.
- 2. Transfers control to the address indicated by the restored PC and PSW.

Figure 4-14 illustrates the restore processing from an exception trap.



Figure 4-14 Restore processing from exception trap



### 4.7.2 Debug trap

The debug trap is an exception that can be acknowledged every time and is generated by execution of the DBTRAP instruction.

When the debug trap is generated, the CPU performs the following processing.

#### (1) Operation

When the debug trap is generated, the CPU performs the following processing, transfers control to the debug monitor routine, and shifts to debug mode.

- 1. Saves the restored PC to DBPC.
- 2. Saves the current PSW to DBPSW.
- 3. Sets the NP, EP and ID bits of the PSW.
- 4. Sets the handler address (0000060H) corresponding to the debug trap to the PC and transfers control.

Figure 4-15 illustrates the processing of the debug trap.



Figure 4-15 Debug trap processing



#### (2) Restore

Recovery from a debug trap is carried out by the DBRET instruction. By executing the DBRET instruction, the CPU carries out the following processing and controls the address of the restored PC.

1. Loads the restored PC and PSW from DBPC and DBPSW.

2. Transfers control to the address indicated by the restored PC and PSW. *Figure 4-16* illustrates the restore processing from a debug trap.



Figure 4-16 Restore processing from debug trap



## 4.8 Multiple Interrupt Processing Control

Multiple interrupt processing control is a process by which an interrupt request that is currently being processed can be interrupted during processing if there is an interrupt request with a higher priority level, and the higher priority interrupt request is received and processed first.

If there is an interrupt request with a lower priority level than the interrupt request currently being processed, that interrupt request is held pending.

Maskable interrupt multiple processing control is executed when an interrupt has an enable status (ID = 0). Thus, if multiple interrupts are executed, it is necessary to have an interrupt enable status (ID = 0) even for an interrupt processing routine.

If a maskable interrupt enable or a software exception is generated in a maskable interrupt or software exception service program, it is necessary to save EIPC and EIPSW.

This is accomplished by the following procedure.

#### (1) Acknowledgment of maskable interrupts in service program

Service program of maskable interrupt or exception

| •EIPC saved to memory or register                   |                      |
|-----------------------------------------------------|----------------------|
| •EIPSW saved to memory or register                  |                      |
| •El instruction (interrupt acknowledgment enabled)  |                      |
|                                                     |                      |
|                                                     | " Maskable interrupt |
|                                                     | acknowledgment       |
| •DI instruction (interrupt acknowledgment disabled) |                      |
| <ul> <li>Saved value restored to EIPSW</li> </ul>   |                      |
| <ul> <li>Saved value restored to EIPC</li> </ul>    |                      |
| •RETI instruction                                   |                      |
|                                                     |                      |



#### (2) Generation of exception in service program

Service program of maskable interrupt or exception

```
...
•EIPC saved to memory or register
•EIPSW saved to memory or register
...
•TRAP instruction
...
•Saved value restored to EIPSW
•Saved value restored to EIPC
•RETI instruction
```

The priority order for multiple interrupt processing control has 8 levels, from 0 to 7 for each maskable interrupt request (0 is the highest priority), but it can be set as desired via software. Setting of the priority order level is done using the PPRn0 to PPRn2 bits of the interrupt control request register (PICn), which is provided for each maskable interrupt request. After system reset, an interrupt request is masked by the PMKn bit and the priority order is set to level 7 by the PPRn0 to PPRn2 bits.

The priority order of maskable interrupts is as follows.

(High) Level 0 > Level 1 > Level 2 > Level 3 > Level 4 > Level 5 > Level 6 > Level 7 (Low)

Interrupt processing that has been suspended as a result of multiple processing control is resumed after the processing of the higher priority interrupt has been completed and the RETI instruction has been executed.

A pending interrupt request is acknowledged after the current interrupt processing has been completed and the RETI instruction has been executed.

**Caution** In a non-maskable interrupt processing routine (time until the RETI instruction is executed), maskable interrupts are suspended and not acknowledged.



## 4.9 Interrupt Response Time

The following table describes the interrupt response time (from interrupt generation to start of interrupt processing).

Except in the following cases, the interrupt response time is a minimum of 4 clocks:

- During software or hardware STOP mode
- · When an external bus is accessed
- When there are two or more successive interrupt request non-sampling instructions (see "Periods in Which Interrupts Are Not Acknowledged" on page 141).
- · When the interrupt control register is accessed

To input interrupt requests continuously, leave a space of at least 4 clocks between interrupt request inputs.

If a peripheral register via the NPB is accessed, the "MEM" cycle of the interrupted instruction may induce additional delay cycles, thus delaying also the fetch of the 1st instruction of the interrupt service routine.



Figure 4-17 Pipeline operation at interrupt request acknowledgment (outline)

| Note | INT1 to INT4: | Interrupt acknowledgement processing |
|------|---------------|--------------------------------------|
|      | IFx:          | Invalid instruction fetch            |
|      | IDx:          | Invalid instruction decode           |

| Table 4-13 | Interrupt response time |
|------------|-------------------------|
|------------|-------------------------|

| Interrupt | response time (inter | nal system clocks)                | Condition                                                                                                                                                         |  |  |  |  |
|-----------|----------------------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|           | Internal interrupt   | External interrupt                | Condition                                                                                                                                                         |  |  |  |  |
| Minimum   | 4                    | 4 + digital noise<br>filter delay | The following cases are exceptions: <ul> <li>In IDLE/software STOP mode</li> </ul>                                                                                |  |  |  |  |
| Maximum   | 8                    | 8 + digital noise<br>filter delay | <ul> <li>External bit access</li> <li>Two or more interrupt request non-sample instructions are executed</li> <li>Access to interrupt control register</li> </ul> |  |  |  |  |



## 4.10 Periods in Which Interrupts Are Not Acknowledged

An interrupt is acknowledged while an instruction is being executed. However, no interrupt will be acknowledged between an interrupt non-sample instruction and the next instruction.

The interrupt request non-sampling instructions are as follows:

- El instruction
- DI instruction
- LDSR reg2, 0x5 instruction (for PSW)
- The store instruction to the following registers:
  - interrupt control registers xxICn
  - interrupt in-service priority register ISPR
  - command register PRCMD
  - Timer T counter write buffer registers TTnTCW



# Chapter 5 CRC Function (CRC)

The microcontroller offers hardware support for Cyclic Redundancy Check (CRC) by its DATA-CRC unit.

## 5.1 Features

### 5.1.1 DATA-CRC

The DATA-CRC can be used to verify or generate CRC protected data streams of arbitrary length and different bit widths.

- 32-bit Ethernet CRC (04C11DB7<sub>H</sub>) ( $X^{32}+X^{26}+X^{23}+X^{22}+X^{16}+X^{12}+X^{11}+X^{10}+X^8+X^7+X^5+X^4+X^2+X^1+1$ ) Input data reflected Output data reflected Final XOR with FFFF FFF<sub>H</sub>
- 16-bit CCITT CRC (1021<sub>H</sub>) (X<sup>16</sup>+X<sup>12</sup>+X<sup>5</sup>+1) Input data not reflected Output data not reflected Final XOR with 0000<sub>H</sub>
- CRC generation to an arbitrary data block length
- One channel for DATA-CRC generation
- After initialization of the DATA-CRC input register every write access to the DATA-CRC input register generates a new CRC according to the chosen polynomial and the result is stored in the DATA-CRC data register.



## 5.2 Configuration



The following picture shows the block diagram of the CRC module.

Figure 5-1 Block diagram of DATA-CRC



## 5.3 CRC Registers

**Caution** The CRC module is addressed via memory controller of the external bus, hence the chip select CS7 of the memory controller (MEMC) must be configured in advance.

The CRC is controlled and operated by means of the following registers:

#### Table 5-1 CRC registers overview

| Register name           | Shortcut | Address                   |
|-------------------------|----------|---------------------------|
| DATA-CRC input register | DCRCIN   | <base/> + 30 <sub>H</sub> |
| DATA-CRC data register  | DCRCD    | <base/> + 34 <sub>H</sub> |
| CRC control register    | CRCC     | <base/> + 40 <sub>H</sub> |

Base address The base address of the CRC module is 0FE0 0000<sub>H</sub>.



#### (1) DCRCIN - DATA-CRC input register

The DCRCIN register is a 32-bit data input register that holds the input data for DATA-CRC calculation. The effective bit width used for CRC calculation must be set at CRCC.ISZn bits of the CRC control register.

The CRC calculation is immediately started after the DCRCIN register is written. The DCRCD register must be initialized, with the initial starting value, before the first data of the data block is written to DCRCIN register.

Access This register can be read/written in 32-bit units.

Address <base> + 30<sub>H</sub>

Initial Value  $0000 0000_{\text{H}}$ . The register is cleared by any reset.

| 31 |               | 16 |
|----|---------------|----|
|    | DCRCIN[31:16] |    |
|    |               |    |
| 15 |               | 0  |
|    | DCRCIN[15:0]  |    |

#### (2) DCRCD - DATA-CRC data register

This register is a 32-bit register for the result storage of the DATA-CRC generated by the 32bit Ethernet or 16-bit CCITT polynomial.

When the 16-bit CCITT polynomial is enabled, the bits 15-0 of the DCRCD register show the CRC result. The bits 31-16 are undefined.

Access This register can be read/written in 32-bit units.

Address <base> + 34<sub>H</sub>

Initial Value 0000 0000<sub>H</sub>. The register is cleared by any reset.

| 31 |              | 16 |
|----|--------------|----|
|    | DCRCD[31:16] |    |
|    |              |    |
| 15 |              | 0  |
|    | DCRCD[15:0]  |    |
|    |              |    |

Caution

1. This register must be initialized, with the initial starting value, before the first data of the data block is written to DCRCIN register.



| (3) | CRCC - | <b>CRC</b> control | register |
|-----|--------|--------------------|----------|
|-----|--------|--------------------|----------|

CCRC is a register that controls the DATA-CRC generation process.

Access This register can be read/written in 32-bit units. The upper 16-bit are fixed to "0".

Address <base> + 40<sub>H</sub>

**Initial Value** 0000<sub>H</sub>. The register is cleared by any reset.

| 31 | 30 | 29 | 28 | 27 | 26   | 25   | 24  |
|----|----|----|----|----|------|------|-----|
| 0  | 0  | 0  | 0  | 0  | 0    | 0    | 0   |
|    |    |    |    |    |      |      |     |
| 23 | 22 | 21 | 20 | 19 | 18   | 17   | 16  |
| 0  | 0  | 0  | 0  | 0  | 0    | 0    | 0   |
|    |    |    |    |    |      |      |     |
| 15 | 14 | 13 | 12 | 11 | 10   | 9    | 8   |
| 0  | 0  | 0  | 0  | 0  | 0    | 0    | 0   |
|    |    |    |    |    |      |      |     |
| 7  | 6  | 5  | 4  | 3  | 2    | 1    | 0   |
| 0  | 0  | 0  | 0  | 0  | ISZ1 | ISZ0 | POL |

| ISZ1 ISZ0 | Select DATA-CRC bit width |
|-----------|---------------------------|
| 00 32-bit |                           |
| 01        | 16-bit                    |
| 10        | 8-bit                     |
| 11        | setting prohibited        |

| POL | Select DATA-CRC generating function                                                                                                                                      |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | 32-bit Ethernet CRC polynomial generation. The byte order of the DCRCIN register is LSB (Least Significant Byte) first, means LSB at bit position 70 of DCRCIN register. |
| 1   | 16-bit CCITT CRC polynomial generation. The byte order of the DCRCIN register is MSB (Most Significant Byte) first, means MSB at bit position 70 of DCRCIN register.     |

**Note** After changing the DATA-CRC generating function (CRCC.POL) the DCRCD register must be initialized.

**Caution** The DATA-CRC bit width (CRCC.ISZn) must be set according to the data block bit width. Switching the DATA-CRC bit width is not allowed during processing of a data block (a data block consists of n bytes, half words or words). After the final DATA-CRC result is read from DCRCD register, the bit width can be changed and the DCRCD register must be initialized with the initial value afterwards.



# 5.4 Operation

# 5.4.1 DATA-CRC

The DATA-CRC module offers the possibility to generate a CRC of an arbitrary data block length with a data width of 8, 16 or 32bit. The CRC polynomial can either be selected for 32-bit Ethernet or 16-bit CCITT, the initial starting value must be set at the DCRCD register before the first write access to the CRC input register (DCRCIN) is done.

The flow chart below shows the DATA-CRC generating procedure.



#### Figure 5-2 DATA-CRC flow diagram

- **Note** 1. After the first data write to the input register DCRCIN, the DATA-CRC operational result is not taken into the CRC data register (DCRCD). But on read access of the DCRCD register the actual CRC value is forwarded to the register and the actual CRC value is read.
  - 2. The CRC data register DCRCD must be initialized if the polynomial is changed by changing bit CRCC.POL.

RENESAS

# **Chapter 6 Clock Generator**

The Clock Generator generates and monitors the internal system clock that is supplied to the CPU and the peripherals.

# 6.1 Overview

The Clock Generator has two oscillators:

- The main oscillator generates the system clock from an external 16 MHz crystal or resonator.
- An internal oscillator generates a clock that is used to monitor the main oscillator. In case of a main oscillator malfunction detection, an interrupt or a reset can be generated, while the micocontroller is operating with the free-running PLL output clock.

# 6.1.1 Features

- Crystal frequency: f<sub>X</sub> = 16 MHz
- Multiplier function using two phase locked loop (PLL) synthesizers:
  - A times 5 multiplier generates f<sub>XX</sub>' = 80 MHz, the high-speed internal system clock for the CPU supply.
  - A times 2 multiplier generates  $f_{XX}$  = 32 MHz for the peripheral clock supply.
- 6.8 MHz internal oscillator
- Built-in Clock Monitor
- Automatic change of CPU clock source if main oscillator fails



# 6.1.2 Description



The following figure shows a simplified block diagram of the Clock Generator:

Figure 6-1 Clock Generator block diagram

| Note | f <sub>X</sub> :   | Main oscillator output clock (16 MHz)                 |
|------|--------------------|-------------------------------------------------------|
|      | f <sub>XX</sub> :  | Internal system clock (PLL $\times$ 2 output, 32 MHz) |
|      | f <sub>XX</sub> ': | Internal system clock (PLL $\times$ 5 output, 80 MHz) |
|      | f <sub>RO</sub> :  | Internal oscillator clock                             |
|      | VBCLK:             | Clock to CPU (80 MHz)                                 |
|      | BCLK:              | Clock to Memory Controller                            |
|      |                    |                                                       |

 $f_{XX} \ \ \text{PLL} \quad \ \ \text{An external crystal has to be connected to the X1 and X2 pins. Its frequency is multiplied by the PLL synthesizer. By this an internal system clock f_{XX} is generated that has 2 times the frequency (f_X) of the external crystal.$ 



The clock controller enables the PLL automatically and starts clock supply to the system after oscillation stabilization time has passed.

- $f_{XX}$ ' PLL An additional PLL, fed with the main oscillator clock  $f_X$ , with a multiplication factor of 5 generates the 80 MHz clock  $f_{XX}$ ', which is used to supply the CPU.
- VBCLK The CPU clock VBCLK is 80MHz.
- **CANCLK** The clock CANCLK for the CAN controllers can be chosen from the peripheral clock PCLK1 or the main oscillator clock  $f_x$ , both having a frequency of 16 MHz. The CANCLK choice is made by CANCKSEL.CANCK0.
  - **PCLK** The peripheral modules are supplied with a set of 10 peripheral clock PCLK0 to PCLK9, derived from the PLL output clock  $f_{xx}$  by a prescaler. The maximum frequency delivers PCLK0 with 32 MHz, the other PCLKn are the half of its predecessor PCLK(n-1).



# 6.2 Control Registers

The Clock Generator is controlled and operated by means of the following register:

#### Table 6-1 Clock Generator registers overview

| Register name                | Shortcut | Address                |
|------------------------------|----------|------------------------|
| CAN clock selection register | CANCKSEL | FFFF F860 <sub>H</sub> |

#### (1) CANCKSEL - CAN clock selection register

The CANCKSEL register determines the clock source of the CAN clock CANCLK.

Access This register can be read/written in 8-bit or 1-bit units.

Address FFFF F860<sub>H</sub>

Initial Value 00<sub>H</sub>. This register is initialized by any reset.

| 7     | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|-------|---|---|---|---|---|---|--------|
| 0     | 0 | 0 | 0 | 0 | 0 | 0 | CANCK0 |
| <br>R | R | R | R | R | R | R | R/W    |

#### Table 6-2 CANCKSEL register contents

| Bit position Bit name |        | Function                                                                                                                                        |  |  |
|-----------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0                     | CANCK0 | <ul> <li>16 MHz CAN clock CANCLK supply selection</li> <li>0: peripheral clock PCLK1</li> <li>1: main oscillator clock f<sub>x</sub></li> </ul> |  |  |



# 6.3 Clock Monitor

The Clock Monitor monitors the operation of the main oscillator.

In case of malfunction of the main oscillator, it can generate the reset CLMRES or the interrupt INTOSD.

If the main oscillator has stopped to operate, the PLLs output their free-running clock frequency at  $f_{XX}$  respectively  $f_{XX}$ '. Thus the CPU system clock VBCLK and the base clock for all peripheral clocks PCLKn is derived from the free-running PLL output clocks.

**Caution** In case of a main oscillator stop, be aware of the following:

- 1. The CPU can operate on the free-running PLL output clock.
- 2. DMA transfers may fail to operate.
- 3. Peripheral modules, supplied by PCLKn, may fail to operate.
- 4. In on-chip debug mode the Clock Monitor is automatically stopped. Read/write of the Clock Monitor's registers is still possible.

**Emergency shut-off** The Clock Monitor interrupt INTOSD is capable to initiate an emergency shut-off (immediate change into high impedance mode) of certain output pins. For further information refer to *"Pin Functions" on page 23*.

# 6.3.1 Clock Monitor registers

The Clock Monitor is controlled and operated by means of the following register:

#### Table 6-3 Clock Monitor registers overview

| Register name               | Shortcut | Address                |  |
|-----------------------------|----------|------------------------|--|
| Clock Monitor mode register | CLM      | FFFF FCA0 <sub>H</sub> |  |



#### (1) CLM - Clock Monitor mode register

The 8-bit CLM register controls the operation of the Clock Monitor.

Writing to this register is only possible immediately after writing to the associated write protection register. First write to the PRCMD register. The contents is ignored. Then, you are permitted to write once to the CLM register. This must be done immediately after writing to the PRCMD register. After the second write action, or if the second write action does not follow immediately, all protected registers are write-locked again.

Access This register can be read/written in 8-bit or 1-bit units.

Address FFFF FCA0<sub>H</sub>

Initial Value 00<sub>H</sub>. This register is initialized by RESET.

| 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0    |
|---|---|---|---|---|---|------|------|
| 0 | 0 | 0 | 0 | 0 | 0 | CLMD | CLME |
| R | R | R | R | R | R | R    | R/W  |

#### Table 6-4 CLM register contents

| Bit position | Bit name | Function                                                                                                                                  |
|--------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 1            | CLMD     | Defines the action if the main oscillator frequency is too<br>low:<br>0: Generate internal reset CLMRES.<br>1: Generate interrupt INTOSD. |
| 0            | CLME     | Clock Monitor enable:<br>0: Disable the Clock Monitor.<br>1: Enable the Clock Monitor.                                                    |

**Note** Once CLM.CLME has been set, it cannot be cleared by writing to the register. This bit can only be cleared by **RESET**.

Caution CLMD must not be changed if the Clock Monitor is enabled (CLME = 1).

Since disabling of the Clock Monitor (CLME = 0) is only carried out by a RESET, it is not possible to change CLMD after the Clock Monitor has been started.



## 6.3.2 Operation of the Clock Monitor

The Clock Monitor counts the falling edges of the main oscillator clock  $f_X$  during a period of 3 clock cycles of the half of the internal oscillator clock  $f_{RO}$  (=  $1/T_{RO}$ ), i.e. within 3 x  $2T_{RO}$ .

In case the number of counted  $f_X$  is less than two, the Clock Monitor issues the reset CLMRES or the interrupt INTOSD, depending on CLM.CLMD.

As the frequency of the internal oscillator is heavily temperature depend,  $f_{RO}$  varies between its minimum  $f_{ROmin}$  (=  $1/T_{ROmin}$ ) and maximum  $f_{ROmax}$  (=  $1/T_{ROmax}$ ) values.

Main oscillator fail<br/>detectionFigure 6-2 illustrates the calculation of the minimum frequency f<br/>Xmin1, that the<br/>Clock Monitor always detects as a main oscillator fail condition.

$$T_{Xmax1} = 3 \cdot 2 \cdot T_{ROmax}$$

and thus

 $f_{Xmin1} = f_{ROmin} / 6$ 

All main oscillator frequencies below  $f_{\mbox{Xmin1}}$  are reported as main oscillator failure.

The main oscillator frequency  $f_X (= 1/T_X)$  in *Figure 6-2* falls below this limit  $f_{Xmin1}$  and the Clock Monitor reports oscillator failure by generating CLMRES respectively INTOSD.



Figure 6-2 Main oscillator fail detection

Main oscillatorFigure 6-3 illustrates the calculation of the minimum frequency f<br/>Xmin2, that the<br/>Clock Monitor always detects as a main oscillator no-fail condition.

$$2 \cdot T_{Xmax2} = 3 \cdot 2 \cdot T_{ROmin}$$

and thus

RENESAS

 $f_{Xmin2} = f_{ROmax} / 3$ 

All main oscillator frequencies above  $f_{\mbox{Xmin2}}$  are judged as main oscillator no-fail.

The main oscillator frequency  $f_X (= 1/T_X)$  in *Figure 6-3* falls below this limit  $f_{Xmin2}$  and the Clock Monitor reports oscillator failure by generating CLMRES respectively INTOSD.



Figure 6-3 Main oscillator "no fail" detection

All main oscillator frequencies between  $f_{Xmin1}$  and  $f_{Xmin2}$  may be detected as oscillator failure.

*Table 6-5* summarizes the main oscillator fail/no-fail detections and gives an example with following internal oscillator frequencies:

- $f_{ROmin} = 5,88 \text{ MHz} \implies T_{ROmax} = 170 \text{ ns}$
- $f_{ROmax} = 8,00 \text{ MHz} \implies T_{ROmin} = 125 \text{ ns}$

For information concerning the real internal oscillator frequencies refer to the Data Sheet.

#### Table 6-5 Main oscillator fail detection

| f <sub>X</sub>                    | <b>Clock Monitor detection</b> | Example                              |
|-----------------------------------|--------------------------------|--------------------------------------|
| $f_X < f_{Xmin1} = f_{ROmin / 6}$ | fail                           | f <sub>X</sub> < 0,98 MHz            |
| $f_{Xmin1} < f_X < f_{Xmin2}$     | fail or no-fail                | 0,98 MHz < f <sub>X</sub> < 2,67 MHz |
| $f_X > f_{Xmin2} = f_{ROmax/3}$   | no-fail                        | f <sub>X</sub> > 2,67 MHz            |

Note Main oscillator frequencies above its nominal value f<sub>X</sub> will not be detected as failure.



# 6.4 Power Save Control

The power save function of V850E/PHC3 supports the HALT mode. In this mode, the Clock Generator (oscillator and PLL synthesizers) continues to operate, but the CPU clock and hence program execution stops. The built-in RAM keeps the state it had before the HALT mode was set.

The clock supply to the on-chip peripherals continues. Peripheral devices that do not require instruction processing remain operating.

The HALT mode can reduce the average power consumption of the entire system by intermittent operation with the normal operation mode.

The system is switched to HALT mode by a specific instruction (the HALT instruction).

*Figure 6-4* shows the transitions between normal operation mode and HALT mode.



Figure 6-4 Power Save Mode State Transition Diagram

- Note 1. Non-maskable interrupt request signal (NMI) or unmasked maskable interrupt request signal.
  - 2. The oscillation stabilization time is necessary after release of reset because the PLL is initialized by a reset. The stabilization time is determined by hardware.



# 6.4.1 HALT mode

### (1) Setting and operation status

The HALT mode is set when a dedicated instruction (HALT) is executed in the normal operation mode.

When HALT mode is set, clock supply is stopped to the CPU only. The Clock Generator and PLL continue operating. Clock supply to the other on-chip peripheral functions continues.

As a result, program execution is stopped, and the internal RAM retains the contents before the HALT mode was set. The on-chip peripheral functions that are independent of instruction processing by the CPU continue operating.

Table 6-6 shows the operation status in the HALT mode.

The average power consumption of the system can be reduced by using the HALT mode in combination with the normal operation mode for intermittent operation.

- Caution 1. Insert five or more NOP instructions after the HALT instruction.
  - 2. If the HALT instruction is executed while an interrupt request is being held pending, the HALT mode is set but is released immediately by the pending interrupt request.

The following table shows the operation status in the HALT mode.

#### Table 6-6 Operation Status in HALT Mode

| Function                                 | Operation Status                                                                                                                                               |
|------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Clock Generator                          | Operating                                                                                                                                                      |
| Internal system clock (f <sub>XX</sub> ) | Supplied                                                                                                                                                       |
| CPU                                      | Stopped                                                                                                                                                        |
| DMA                                      | Operating                                                                                                                                                      |
| Interrupt controller                     | Operating                                                                                                                                                      |
| Ports                                    | Maintained                                                                                                                                                     |
| On-chip peripheral I/O (excluding ports) | Operating                                                                                                                                                      |
| Internal data                            | All internal data such as CPU registers,<br>states, data, and the contents of internal<br>RAM are retained in the state they were<br>before HALT mode was set. |

#### (2) Releasing HALT mode

The HALT mode is released by a non-maskable interrupt request signal (NMI), an unmasked maskable interrupt request signal, or any reset.

After the HALT mode has been released, the normal operation mode is restored.

RENESAS

# (a) Releasing HALT mode by non-maskable interrupt request signal or unmasked maskable interrupt request signal

The HALT mode is released by a non-maskable interrupt request signal or an unmasked maskable interrupt request signal, regardless of the priority of the interrupt request. If the HALT mode is set in an interrupt servicing routine, however, an interrupt request that is issued later is serviced as follows.

- If an interrupt request signal with a priority lower than or same as the interrupt currently being serviced is generated, the HALT mode is released, but the newly generated interrupt request signal is not acknowledged. The interrupt request signal itself is retained.
- If an interrupt request signal with a priority higher than that of the interrupt currently being serviced is issued (including a non-maskable interrupt request signal), the HALT mode is released and that interrupt request signal is acknowledged.

### Table 6-7 Operation after releasing HALT mode by interrupt request signal

| Release Source                                | Interrupt Enabled (EI) Interrupt Disabled<br>Status Status                    |                                  |  |  |
|-----------------------------------------------|-------------------------------------------------------------------------------|----------------------------------|--|--|
| Non-maskable interrupt request signal         |                                                                               |                                  |  |  |
| Unmasked maskable<br>interrupt request signal | Execution branches to the handler address or the next instruction is executed | The next instruction is executed |  |  |

#### (b) Releasing HALT mode by reset

The same operation as the normal reset operation is performed.



# **Chapter 7 Flash Memory**

The V850E/PHC3 microcontroller is equipped with following internal flash memory:

- · Code flash:
  - μPD70F3485: 480 KB
- Data flash: 32 KB

The code flash memory is attached to the dedicated fetch bus interface of the V850 CPU core. It is used for non-volatile storage of program code and constant data.

The data flash memory is accessible via the memory interface bus. It holds nonvolatile user's data, which are subject to be altered during normal program operation.

Flash memory is commonly used in the following development environments and applications:

- For altering software after solder-mounting of the V850 microcontroller on the target system.
- For differentiating software in small-scale production of various models.
- For data adjustment when starting mass production.
- For facilitating inventory management.
- For updating software after shipment.

The flash memory can be written in different ways:

- by a flash programmer equipped with a suitable adapter (off-board write)
- mounted on the target board by connecting a dedicated flash programmer to the target system (on-board write)
- by the V850 microcontroller's application software (self-programming)



# 7.1 Code Flash Memory Overview

## 7.1.1 Code flash memory features

- Internal code flash memory:
  - : 480 KB
- Operation speed: 80 MHz by 2-way interleaved access
  - 4-byte/1 CPU clock cycle access for consecutive instruction fetches
  - 4-byte/5 CPU clock cycles access for random instruction and data fetches
- All-blocks batch erase or single block erase
- Erase/write with single power supply
- · Communication with dedicated flash programmer via two serial interfaces
- On-board and off-board programming
- Flash memory programming by self-programming
- 7-bit ECC (error correction code) for every 4 bytes
  - 1 bit error: automatic correction
  - 2 bit errors: detection
  - Specific interrupt generation in case of bit errors

# 7.1.2 Code flash memory mapping

The V850 microcontroller's internal code flash memory area is divided into blocks of 4 KB blocks and can be programmed/erased in block units. All or some of the blocks can also be erased at once.

Following figures list the block structures and address assignments of the code flash memory.

Additional information comprise:

- Boot swap cluster size Configurable size of boot cluster for secure self-programming, refer to "Secure self-programming (boot cluster swapping)" on page 183.
- Interleave
   Interleave configuration of the flash memory blocks.
- CPU branch latency Number of additional CPU clock cycles during instruction fetches of nonlinear code.



|                  | 0007 7FFFH               |         |
|------------------|--------------------------|---------|
| Block 119 (4 KB) |                          |         |
|                  | 0007 7000H               |         |
|                  |                          |         |
|                  |                          |         |
|                  |                          |         |
| Block OC (4 KB)  | 0006 0FFFH               |         |
| Block 96 (4 KB)  | 0000 000011              |         |
|                  | 0006 0000H<br>0005 FFFFH | Ś       |
| Block 95 (4 KB)  |                          | Address |
| DIOCK 95 (4 KD)  | 0005 F000H               | ddr     |
|                  | 0003 F000H               | Ā       |
|                  |                          |         |
|                  |                          |         |
|                  | 0000 1FFFH               |         |
| Block 1 (4 KB)   |                          |         |
|                  | 0000 1000H               |         |
|                  | 0000 0FFFH               |         |
| Block 0 (4 KB)   |                          |         |
|                  | 0000 0000H               |         |
| 480 KB           | Code flash size          |         |
| 64 KB            | Boot swap cluster sizes  | 6       |
| 2-way            | Interleave               |         |
| 4 cycles         | CPU branch latency       |         |
|                  | Products                 |         |

Figure 7-1 Code flash memory configuration



## 7.1.3 Code flash memory functional outline

**Serial programming** The internal flash memory of the V850 microcontroller can be rewritten by using the rewrite function of a dedicated flash programmer, regardless of whether the V850 microcontroller has already been mounted on the target system or the device is not mounted (off-board/on-board programming).

Since there is no functional difference between on-board and off-board programming by an external flash programmer, both will be gathered as "serial programming" - in contrast "to self-programming".

**Self-programming** The self-programming facility, which facilitates rewriting of the flash memory by the user program, is ideal for program updates after production and shipment, since no additional programming equipment is required. During self-programming some software services as well as interrupt serving can still be in operation, e.g to sustain communication with other devices.

While the self-programming mode can be initiated from the normal operation mode the external flash programmer mode is entered immediately after release of a system reset. Refer to *"Flash memory programming control" on page 175* for details on how

**Extra area** The flash memory contains an extra area, used to store the settings of security and protection functions and other flash relevant information. The extra area is not mapped into the CPU's address space, thus is not directly accessible by the user's program. The extra area's settings can only be read and modified by an external programmer or by the self-programming library.

to enter normal operation or serial flash programming mode.

- **Boot swap** A boot swap function makes safe re-programming of the flash memory possible and is used to maintain an operable software version, even if re-programming fails for any reason, e.g. in a power fail situation. For further information concerning boot swapping refer to *"Secure self-programming (boot cluster swapping)" on page 183*.
- Protection A set of protection flags can be specified during flash memory programming to prohibit access the flash memory in different ways, implying read-out, rewrite and erase protections. By these means the code flash memory can be protected against read-out and rewrite of the flash memory content by unauthorized persons.
   For further information concerning data protection refer to "Data Protection and Security" on page 187.

| Environment           | Interface                 | Outline                                                                                                                                                                                                                                                                                                                                                                                                                         | Operation Mode                      |
|-----------------------|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|
| Serial<br>programming | Serial I/F (UART,<br>CSI) | Flash memory programming is done by an external<br>flash programmer.<br>The device may be mounted on the target system (on-<br>board) or unmounted (off-board) by using a suitable<br>programming adapter board. In either case the<br>communication between the device and the flash<br>progammer is using a serial interface.<br>For details refer to <i>"Flash Programming with Flash</i><br><i>Programmer" on page 170.</i> | Flash memory<br>programming<br>mode |

 Table 7-1
 Flash memory write methods



| Environment          | Interface                   | Outline                                                                                                                                                                                                                                                                                                                                                   | Operation Mode           |
|----------------------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| Self-<br>programming | Self-programming<br>library | Flash memory can be rewritten by executing a user<br>program that has been written to the flash memory in<br>advance by means of off-board/on-board<br>programming. The self-programming library provides<br>all necessary functions to be called by the user's<br>software.<br>For details refer to <i>"Code Flash Self-Programming"</i> on<br>page 181. | Normal operation<br>mode |

 Table 7-1
 Flash memory write methods

*Table 7-2 on page 164* summarizes the functions used to modify flash memory content.



| Eurotional outline                                                                                                                                                            | Support<br>(√: Supported, ×: Not supported)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                                                                                                                                                                               | Serial programming                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Self-programming                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| The contents of specified memory blocks are erased.                                                                                                                           | $\checkmark$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | $\checkmark$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| The contents of the specified successive multiple blocks are erased.                                                                                                          | $\checkmark$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | $\checkmark$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| The contents of the entire memory area is erased all<br>at once. The extra area - except the boot block<br>cluster protection flag - is also erased.                          | ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| Caution: The chip erase function erases also the data flash memory.                                                                                                           | $\checkmark$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | x <sup>a</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| Writing to specified addresses, and a verify check to see if write level is secured are performed.                                                                            | $\checkmark$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | $\checkmark$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| Data read from the flash memory is compared with data transferred from the flash programmer.                                                                                  | $\checkmark$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | x <sup>b</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| Microcontroller internally calculated checksum over<br>the entire flash memory content is compared with the<br>checksum calculated by the external programmer                 | $\checkmark$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| The erasure status of the entire memory is checked.                                                                                                                           | $\checkmark$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | $\checkmark$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| <ul> <li>Following functions can be prohibited:</li> <li>chip erase</li> <li>block erase</li> <li>write</li> <li>read</li> <li>rowriting of the best block eluster</li> </ul> | $\checkmark$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | √ c                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|                                                                                                                                                                               | The contents of the specified successive multiple<br>blocks are erased.<br>The contents of the entire memory area is erased all<br>at once. The extra area - except the boot block<br>cluster protection flag - is also erased.<br><b>Caution:</b> The chip erase function erases also the<br>data flash memory.<br>Writing to specified addresses, and a verify check to<br>see if write level is secured are performed.<br>Data read from the flash memory is compared with<br>data transferred from the flash programmer.<br>Microcontroller internally calculated checksum over<br>the entire flash memory content is compared with the<br>checksum calculated by the external programmer<br>The erasure status of the entire memory is checked.<br>Following functions can be prohibited:<br>• chip erase<br>• block erase<br>• write | (√: Supported,<br>Serial<br>programming         The contents of specified memory blocks are erased.       √         The contents of the specified successive multiple<br>blocks are erased.       √         The contents of the entire memory area is erased all<br>at once. The extra area - except the boot block<br>cluster protection flag - is also erased.       √         Caution:       The chip erase function erases also the<br>data flash memory.       √         Writing to specified addresses, and a verify check to<br>see if write level is secured are performed.       √         Data read from the flash memory is compared with<br>data transferred from the flash programmer.       √         Microcontroller internally calculated checksum over<br>the entire flash memory content is compared with the<br>checksum calculated by the external programmer       √         The erasure status of the entire memory is checked.       √         Following functions can be prohibited:       √         • write       •         • write       •         • write       • |  |  |

Table 7-2 Basic functions for flash memory modifications

<sup>a)</sup> In self-programming mode all blocks can be specified to be erased at once by block erasure. Note that the extra area is not erased in this case.

b) Can be carried out by the user's program.

c) Except protection against rewriting of the boot block cluster all other protections have no effect in self-programming mode.

Protection settings can be activated in self-programming mode. Already activate protection settings can not be deactivated.

The following table lists the available flash memory protection functions.

For details refer to "Data Protection and Security" on page 187.

# 7.1.4 Code flash memory erasure and rewrite

**Erasure** According to its block structure the flash memory can be erased in two different modes.

- All-blocks batch erasure
   All blocks are erased all together.
- Block erasure

Each 4 KB flash memory block can be erased separately.

In self-programming mode any number of contiguous flash memory blocks can be erased all together.



| Function                        | Functional outline                                                                                                  | Applicable<br>(√: applies, ×: doesn't apply) |                  |  |  |
|---------------------------------|---------------------------------------------------------------------------------------------------------------------|----------------------------------------------|------------------|--|--|
| T unction                       |                                                                                                                     | Serial programming                           | Self-programming |  |  |
| Chip erase<br>command prohibit  | Erasure of the entire flash (including the extra area <sup>a</sup> and the data flash) or single blocks impossible. | $\checkmark$                                 | ×                |  |  |
| Block erase<br>command prohibit | Erasure of single blocks impossible.                                                                                | $\checkmark$                                 | ×                |  |  |
| Program command prohibit        | Erasure and rewrite of single blocks impossible.                                                                    | V                                            | ×                |  |  |
| Read command prohibit           | Read-out of any flash content impossible.                                                                           | $\checkmark$                                 | ×                |  |  |
| Rewriting boot area prohibit    | Erasure (by block or chip erase) or writing of the boot block cluster impossible.                                   | $\checkmark$                                 | $\checkmark$     |  |  |

### Table 7-3Protection functions

a) The boot block cluster protection flag is not erased.

**Rewrite** In self-programming and serial programming mode it is possible to rewrite the flash memory in smaller units than one block. Once a complete block has been erased it can be rewritten in units of 8 byte, starting at 8 byte aligned addresses, i.e. at 000<sub>B</sub> as the lower 3 address bits. Each unit can be rewritten only once after erasure of the complete block.



## 7.1.5 Code flash memory error detection

The code flash memory control circuit is equipped with an error detection function. A 7-bit ECC (Error Correction Coding) code is dedicated to each 32-bit word in the flash memory.

The ECC can detect and correct single bit errors and detect double bit errors. In the latter case the double error detection interrupt INTDEDF is generated.

INTDEDF can generate two kinds of interrupts:

- an NMI via the NMI sharing function
- a maskable interrupt (exception code 0080<sub>H</sub>), that is shared with double error detections of the RAM error detection functions

Besides generating an non-maskable or maskable interrupt, the address of the erroneous data is saved a register.

**Note** As error detection is also performed on instructions, which are prefetched by the CPU's execution pipeline, an error may be detected and reported, even if the instruction is not attempted to be executed because of a program branch.

One register is provided for the error correction function.

#### (1) ROMEAD - Flash ROM ECC error register

The 32-bit ROMEAD register holds the address of the flash memory location, where an error was detected first.

Access This register can be read in 32-bit units.

Address FFFF F8A0<sub>H</sub>

Initial Value 0000 0000<sub>H</sub>

| 31 | 30 | 29 | 28 | 27 | 26 | 25   | 24   | 23 | 22 | 21 | 20 | 19 | 18 | 17   | 16 |
|----|----|----|----|----|----|------|------|----|----|----|----|----|----|------|----|
| 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0    | 0  | 0  | 0  | 0  | 0  | RC | MEAD | DR |
| 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8    | 7  | 6  | 5  | 4  | 3  | 2  | 1    | 0  |
|    |    |    |    |    |    | ROME | ADDR |    |    |    |    |    |    | 0    | 0  |

Table 7-4 ROMEAD register contents

| Bit Position | Bit Name | Function                                                |
|--------------|----------|---------------------------------------------------------|
| 18 - 2       | ROMEADDR | 19-bit address of first detection of a flash ROM error. |

The address of the first error detection is stored in ROMEAD. At the same time the interrupt flag INTERRF.INTERR0 is set to 1.

This register is not overwritten by a new error detection until

- the INTERRF.INTERR0 is cleared to 0. Thus no new error is signaled by interrupt INTDEDF until the INTERRF.INTERR0 is cleared to 0.
- ROMEAD is cleared to 0000 0000<sub>H</sub> by any reset.

Afterwards a new ECC detection address can be stored.



#### (2) Flash memory error detection check

For checking the functionality of the flash memory error detection, a dedicated address in the flash memory needs to be reserved for generating a mismatch between the flash memory data word an its associated ECC.

This flash memory address needs to be programmed twice:

- 1. The first data written to the address generates the correct ECC
- 2. The second data written to the same address must differ to the first data. Consider that during re-programming only "1" bits can be changed to "0", but not vice versa. Further the correct ECC of the second data must differ to the correct ECC of the first data.

Afterwards any read of the data (either as an instruction fetch or as a read of a constant) should generate a maskable or non-maskable flash memory error interrupt INTDEDF.



# 7.2 Data Flash Memory

The V850E/PHC3 microcontroller contains a 32 KB data flash in addition to the code flash. The on-chip data flash is connected to the memory bus contoller (MEMC).

# 7.2.1 Data flash memory features

The data flash has the following features:

- 32 KB of data flash memory in 2 KB blocks
- Write access in 32-bit steps
- Erase in 2 KB blocks
- Write, erase operations to the data flash while user's code can be executed from code flash
- **Note** Renesas Electronics provides sample code for a library enabling the flexible emulation of an EEPROM. By means of this library the emulated number of write/erase cycles can be extended far beyond the number of maximum write/erase cycles specified in the Data Sheet.

# 7.2.2 Data flash memory map

The on-chip data flash is connected to the memory bus controller (MEMC). The data flash is mapped to the  $\overline{CS1}$  area to address range 3E0 0000<sub>H</sub> to 3E0 7FFF<sub>H</sub>.

The memory interface has to be set up as follows:

| Table 7-5 | BCU/MEMC register settings for data flash access |
|-----------|--------------------------------------------------|
|-----------|--------------------------------------------------|

| Control bit          | Required setting | Comment                                                                           |
|----------------------|------------------|-----------------------------------------------------------------------------------|
| BCT0.ME1             | 1                | <ul> <li>enable CS1</li> <li>no default, must be changed</li> </ul>               |
| AWC.AHW1<br>AWC.ASW1 | 00 <sub>B</sub>  | <ul><li>no address setup/hold waits</li><li>no default, must be changed</li></ul> |
| DWC0.DWC1[2:0]       | 001 <sub>B</sub> | <ul><li> 1 data wait state</li><li> no default, must be changed</li></ul>         |
| BCC.BC11             | 0                | <ul><li>no idle states</li><li>no default, must be changed</li></ul>              |

For further information about the memory interface configuration refer to *"Bus and Memory Control (BCU, MEMC)" on page 192.* 



# 7.2.3 Data flash control register

#### (1) DFLCTL - Data flash control register

The data flash is controlled with the data flash control register DFLCTL to enable the access to the data flash and to define the memory address location.

Writing to this register is protected by a special sequence of instructions. Please refer to *"Write Protected Registers" on page 97*.

Access This register can be read/written in 8-bit or 1-bit units.

Address FFFF FCF8<sub>H</sub>

Initial value 00<sub>H</sub>. This register is cleared by any reset.

| 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|-----|-----|-----|-----|-----|-----|-----|
| DFLEN | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| R/W   | R/W | R/W | R/W | R/W | R/W | R/W | R/W |

| Bit position | Bit name | Function                                                      |  |
|--------------|----------|---------------------------------------------------------------|--|
| 7            | DFLEN    | Read access control of data flash:<br>0: Disable<br>1: Enable |  |

# 7.2.4 Data flash reading

The data flash can be read via the external memory bus.

Reading of the data flash is performed with the following procedure:

- 1. Enable the read access to the data flash by setting the DFLCTL.DFLEN = 1.
- 2. Execute read operation

# 7.2.5 Data flash writing

The data flash can be written by using the data flash library or serial programming with an external flash programmer tool.

Programming during normal operation is achieved by using the data flash access layer software library. The data flash access layer is described in a separate User's Manual.

**Note** The chip erase command of an external programmer erases also the data flash.



# 7.3 Flash Programming with Flash Programmer

A dedicated flash programmer can be used for external writing of the flash memory.

- On-board programming The contents of the flash memory can be rewritten with the V850 microcontroller mounted on the target system. Mount a connector that connects the flash programmer on the target system.
- Off-board programming The flash memory of the V850 microcontroller can be written before the device is mounted on the target system, by using a dedicated programming adapter.

# 7.3.1 Programming environment

The necessary environment to write a program to the flash memory of the V850 microcontroller is shown below.



Figure 7-2 Environment to write program to flash memory

A host machine is required for controlling the flash programmer.

Following V850 microcontroller serial interfaces can be used as the interface between the flash programmer and the V850 microcontroller:

- asynchronous serial interface UART
- clocked serial interface CSI

If a CSI interface is used with handshake, the flash programmer's HS signal is connected to a certain V850 port, in the following generally named as HSPORT. The port used as HSPORT for this product is given in *Table 7-8*.

Flash memory programming off-board requires a dedicated programming adapter.

In this chapter the terms UART and CSI may be used generically for the dedicated interface types and channels the V850 microcontroller provides. UART and CSI signal names are used accordingly.



# 7.3.2 Communication mode

The communication between the flash programmer and the V850 microcontroller utilizes the asynchronous serial interface UART or optionally the synchronous serial interface CSI.

For programming via the synchronous serial interface CSI without handshake and with handshake modes are supported. In the latter mode the port pin HSPORT is used for the programmer's handshake signal HS.

## (1) UART

The external flash programmer offers various choices of available baud rates.



Figure 7-3 Communication with flash programmer via UART

#### (2) CSI without handshake

The external flash programmer offers various choices of available clock rates.



Figure 7-4 Communication with flash programmer via CSI without handshake

The flash programmer outputs a transfer clock and the V850 microcontroller operates as a slave.



### (3) CSI with handshake (CSI + HS)

The external flash programmer offers various choices of available clock rates.



Figure 7-5 Communication with flash programmer via CSI with handshake

The flash programmer outputs a transfer clock and the V850 microcontroller operates as a slave.

**HSPORT** The microcontroller port used for the handshake signal HS is specified in *Table 7-8 on page 174*.



## 7.3.3 Pin connection with flash programmer PG-FP5

A connector must be mounted on the target system to connect the flash programmer for on-board writing. In addition, functions to switch between the normal operation mode and flash memory programming mode and to control the V850 microcontroller's reset pin must be provided on the board.

When the flash memory programming mode is set, all the pins not used for flash memory programming are in the same status as immediately after reset.

If the PG-FP5 is used as the flash programmer, it generates the signals listed in *Table 7-7* for the V850 microcontroller. For details, refer to the *PG-FP5 User's Manual (R20UT0008E)*.

|                 | PG-FP5                |                                                       |                     |              | Connection   | I            |
|-----------------|-----------------------|-------------------------------------------------------|---------------------|--------------|--------------|--------------|
| Signal name     | name I/O Pin function |                                                       | Pin name            | UART         | CSI          | CSI + HS     |
| FLMD0           | Output                | Write enable/disable                                  | FLMD0               | $\checkmark$ |              |              |
| FLMD1           | Output                | Write enable/disable                                  | FLMD1               | ×            | ×            | ×            |
| V <sub>DD</sub> | I/O                   | V <sub>DD</sub> voltage<br>generation/voltage monitor | V <sub>DD</sub>     | $\checkmark$ | V            |              |
| GND             | -                     | Ground                                                | V <sub>SS</sub>     | $\checkmark$ |              |              |
| CLK             | Output                | Clock output to the controller                        | X1                  | ×            | ×            | ×            |
| RESET           | Output                | Reset signal                                          | RESET               | $\checkmark$ | $\checkmark$ |              |
| SI/RXD          | Input                 | Receive signal                                        | SO/TXD              | $\checkmark$ |              | $\checkmark$ |
| SO/TXD          | Output                | Transmit signal                                       | SI/RXD              | $\checkmark$ |              |              |
| SCK             | Output                | Transfer clock                                        | SCK                 | ×            |              | $\checkmark$ |
| HS              | Input                 | Handshake signal for<br>CSI + HS communication        | HSPORT <sup>a</sup> | ×            | ×            |              |

Table 7-7 Signals generated by flash programmer PG-FP5

<sup>a)</sup> The microcontroller port used for the handshake signal HS is specified in *Table 7-8 on page 174*.

Note  $\sqrt{}$ : Must be connected.

×: Does not have to be connected.



| Flash programmer (FG-FP5) connection<br>pin |     |                                  | Name of FA<br>board pin | UARTC0             | CSIB0 + HS         | CSIB0             |  |
|---------------------------------------------|-----|----------------------------------|-------------------------|--------------------|--------------------|-------------------|--|
| Signal name                                 | I/O | Pin function                     | board pin               | Pin name           | Pin name           | Pin name          |  |
| SI/RxD                                      | I   | Receive signal                   | SI                      | TXDC0              | SC                 | B0                |  |
| SO/TxD                                      | 0   | Transmit signal                  | SO                      | RXDC0              | SI                 | B0                |  |
| SCK                                         | 0   | Transfer clock                   | SCK                     | Not needed         | SCI                | <b0< td=""></b0<> |  |
| CLK                                         | 0   | Clock to V850                    | X1                      |                    | Leave open         |                   |  |
|                                             |     | microcontroller                  | X2                      |                    | Leave open         |                   |  |
| RESET                                       | 0   | Reset signal                     | RESET                   |                    | RESET              |                   |  |
| FLMD0                                       | I   | Write voltage                    | FLMD0                   |                    | FLMD0              |                   |  |
| FLMD1                                       | I   | Write voltage                    | FLMD1                   | FLMD1              |                    |                   |  |
| HS                                          | I   | Handshake signal<br>for CSI + HS | HS                      | Not needed         | HSPORT =<br>P110   | Not needed        |  |
| VDD                                         | -   | VDD voltage                      | VDD                     |                    | VDD                |                   |  |
|                                             |     | generation/<br>voltage monitor   |                         | V <sub>DD1</sub>   |                    |                   |  |
|                                             |     |                                  |                         | BV <sub>DD</sub>   |                    |                   |  |
|                                             |     |                                  |                         | EVDD               |                    |                   |  |
|                                             |     |                                  |                         | AV <sub>REF0</sub> |                    |                   |  |
|                                             |     |                                  |                         |                    | AV <sub>REF1</sub> |                   |  |
| GND                                         | -   | Ground                           | GND                     |                    | Vss                |                   |  |
|                                             |     |                                  |                         | V <sub>SS1</sub>   |                    |                   |  |
|                                             |     |                                  |                         | BVss               |                    |                   |  |
|                                             |     |                                  |                         | EVss               |                    |                   |  |
|                                             |     |                                  |                         |                    | AVss               |                   |  |
|                                             |     | AVssi                            |                         | AV <sub>SS1</sub>  |                    |                   |  |

## Table 7-8 Wiring of V850E/PHC3 flash writing adapters for UARTC and CSIB

## Table 7-9 V850E/PHC3 pin numbers for serial programming

| Pin name | Port | V850E/PHC3<br>pin no. |
|----------|------|-----------------------|
| TXDC0    | P31  | 32                    |
| RXDC0    | P30  | 31                    |
| SIB0     | P40  | 71                    |
| SOB0     | P41  | 72                    |
| SCKB0    | P42  | 73                    |
| RESET    | -    | 34                    |
| FLMD0    | _    | 82                    |
| FLMD1    | _    | 81                    |
| HS/P110  | P110 | 87                    |



# 7.3.4 Flash memory programming control

The procedure to program the flash memory is illustrated below.



Figure 7-6 Flash memory programming procedure



#### (1) Operation mode control

To rewrite the contents of the flash memory by using the flash programmer, set the V850 microcontroller in the flash memory programming mode.

To set this mode, set the FLMD0 and FLMD1 pins as shown in *Table 7-10 on page 176* and release RESET.

In the normal operation mode, 0 V is input to the FLMD0 pin. A pull-down resistor at the FLMD0 pin ensures normal operation mode if no flash programmer is connected. In the flash memory programming mode, the V<sub>DD</sub> write voltage is supplied to the FLMD0 pin. Additionally the FLMD1 pin has to hold 0 V level.

#### Table 7-10 Operation mode setting

|                 | Pins            | Operation mode         |
|-----------------|-----------------|------------------------|
| FLMD0           | FLMD1           |                        |
| V <sub>SS</sub> | V <sub>SS</sub> | Normal operation mode  |
| V <sub>DD</sub> | V <sub>SS</sub> | Flash programming mode |
|                 | V <sub>DD</sub> | Setting prohibited     |

An example of connection of the FLMD0 and FLMD1 pins is shown below. FLMD1 can be connected to ground via a resistor. Alternatively the FLMD1 pin may also be connected directly to the FLMD1 signal of the flash programmer.



Figure 7-7 Example of connection to flash programmer PG-FP5

Once started in normal operation mode (FLMD0 = 0), FLMD0 pin is used for enabling self-programming. Refer also to *"Code Flash Self-Programming" on page 181*.



#### (2) Potential conflicts with on-board signal connections

Serial I/O signals

If other devices are connected to the serial interface pins in use for flash memory programming in on-board programming mode take care that the concerned signals do not conflict with the signals of the flash programmer and the V850 microcontroller. Output pins of the other devices must be isolated or set in high impedance state. Ensure that the other devices do not malfunction because of flash programmer signals.



Figure 7-8 Potential conflicts with serial interfaces signals



**RESET** Pay attention in particular if the flash programmer's **RESET** signal is connected also to an on-board reset generation circuit. The reset output of the reset generator may ruin the flash programming process and may need to be isolated or disabled.



#### Figure 7-9 Potential conflict with RESET

Ports The V850 port pins adopts following status during serial programming:

Ports used for programming are configured as UART respectively CSI pins.

All other pins remain in their default state after reset release.

In case the default state after reset of the pins not used for programming is inport port or high -impedance output port, pay attention to other devices connected to these pins. If these devices require defined levels at the pins, the ports may have to be connected to V<sub>DD</sub> or V<sub>SS</sub> via a resistors.

- **Oscillators** Connect all oscillator pins in the same way as in the normal operation mode.
  - **DRST** During flash memory programming, input a low level to DRST or leave it open. Do not input a high level.
- **Power supply** Supply the same power to all power supply pins, including reference voltages, power regulator pins, etc., as in the normal operation mode.



#### (3) Selection of the communication mode

The communication interface is chosen by applying a specified number of pulses to the FLMD0 pin after reset release. Note that this is handled by the flash programmer.

*Figure 7-10 on page 179* gives an example how the UART is established for the communication between the flash programmer and the V850 microcontroller.



Figure 7-10 Selection of communication mode

**Note** The number of clocks to be inserted differs depending on the chosen communication mode. For details, refer to *Table 7-11 on page 179*.

| Table 7-11 | FLMD0 pulses for communication mode setting |
|------------|---------------------------------------------|
|------------|---------------------------------------------|

| FLMD0 pulses | Communication Mode | Remarks                                               |  |  |
|--------------|--------------------|-------------------------------------------------------|--|--|
| 0            | UART               | Communication rate: 9600 bps (after reset), LSB first |  |  |
| 8            | CSI                | V850E/PHC3 performs slave operation, MSB first        |  |  |
| 11           | CSI + HS           | V850E/PHC3 performs slave operation, MSB first        |  |  |
| Other        | -                  | Setting prohibited                                    |  |  |

When UART has been selected after reception of the FLMD0 pulses with 9600 bps, the flash programmer changes the baud rate according to the user's choice via the flash programmer's user interface.

At first the programmer sends two  $00_H$  bytes, which are used by the microcontoller to measure the baud rate and to set up it's own baud rate accordingly.



#### (4) Communication commands

The flash programmer sends commands to the V850 microcontroller. Depending on the commands, the V850 microcontroller returns status information or the requested data.



Figure 7-11 Communication commands exchange

The following table lists the flash memory control commands of the V850 microcontroller. All these commands are issued by the flash programmer, and the V850 microcontroller performs the corresponding processing.

| Table 7-12 | Flash memory | y control | commands |
|------------|--------------|-----------|----------|
|------------|--------------|-----------|----------|

| Classification | Command name                          | Support      |              |              | Function                                                                                                       |
|----------------|---------------------------------------|--------------|--------------|--------------|----------------------------------------------------------------------------------------------------------------|
| Classification | Command name                          | CSIB         | CSIB + HS    | UARTA        | Tunction                                                                                                       |
| Blank check    | Block blank check<br>command          | $\checkmark$ | $\checkmark$ | $\checkmark$ | Checks erasure status of entire memory.                                                                        |
| Erase          | Chip erase command                    | $\checkmark$ | $\checkmark$ | $\checkmark$ | Erases all memory contents.                                                                                    |
|                | Block erase command                   | $\checkmark$ | $\checkmark$ | $\checkmark$ | Erases memory contents of specified block.                                                                     |
| Write          | Write command                         | $\checkmark$ | $\checkmark$ | $\checkmark$ | Writes data by specifying write<br>address and number of bytes to<br>be written, and executes verify<br>check. |
| Verify         | Verify command                        | $\checkmark$ | $\checkmark$ | $\checkmark$ | Compares input data with all memory contents.                                                                  |
| System setting | Reset command                         | $\checkmark$ | $\checkmark$ | $\checkmark$ | Escapes from each status.                                                                                      |
| and control    | Oscillation frequency setting command | $\checkmark$ | $\checkmark$ | $\checkmark$ | Sets oscillation frequency.                                                                                    |
|                | Baud rate setting command             | _            | -            | $\checkmark$ | Sets baud rate when UART is used.                                                                              |
|                | Silicon signature command             | $\checkmark$ | $\checkmark$ | $\checkmark$ | Reads silicon signature information.                                                                           |
|                | Version acquisition command           | $\checkmark$ | $\checkmark$ | $\checkmark$ | Reads version information of device.                                                                           |
|                | Status command                        | $\checkmark$ | $\checkmark$ | -            | Acquires operation status.                                                                                     |
|                | Protection setting command            | $\checkmark$ | $\checkmark$ | $\checkmark$ | Sets protection against chip<br>erasure, block erasure, and<br>writing.                                        |



# 7.4 Code Flash Self-Programming

This V850 microcontroller supports a flash macro service that allows the user program to rewrite the internal flash memory by itself.

By using this flash macro service and a self-programming library, provided by Renesas Electronics, the user's program is able to rewrite the flash memory with data, transferred in advance to the internal RAM.

Thus the user program can be upgraded and constant data can be rewritten in the field.



#### Figure 7-12 Concept of self-programming

During self-programming access to the flash memory is not possible. Thus program execution is only possible by instruction fetching from internal RAM.

Consequently the instructions of user re-programming software routines, which shall remain in operation during the self-programming procedure, must be copied from the flash memory to the internal RAM prior to activating the self-programming. Since interrupt processing by using the interrupt vectors in the flash memory is also impossible during self-programming, a special feature is provided to re-route interrupt acknowledges to the internal RAM (refer to *"Interrupt handling during flash self-programming" on page 186*).

It is recommended to refer to the *Application Note "Self-Programming"* (*document no. U16929EE*) for comprehensive information concerning flash self-programming. This document explains also the functions of the self-programming library. The latest version of this document and the library can be loaded via the URL

http://www.renesas.eu

**Caution** The self-programming operation employs also the internal Firmware, which makes use of 9 KB of the internal RAM in the address range FFFF  $CC00_H$  to FFFF EFFF<sub>H</sub>.

Thus this RAM area is overwritten and must be re-initialized after completion of the self-programming.

Consider also that the stack occupies additionally up to 1 KB of the RAM.

RENESAS

# 7.4.1 Self-programming enable

The self-programming functions can be started out of the normal user mode of the V850 microcontroller.

The V850 microcontroller must be set into self-programming mode via the self-programming library.

For security reasons writing and erasing of the flash memory must be additionally permitted by setting the external FLMD0 pin to high level. Note that FLMD0 holds low level in normal operation mode after reset release.

This requires some external components or wiring, e.g. connecting an output port to FLMD0.



#### Figure 7-13 Self-programming enable

When self-programming has been completed, the voltage on the FLMD0 pin must be returned to 0 V.

# 7.4.2 Self-programming library functions

Code flash memory self-programming by the user's program is supported by the self-programming library.

This library provides a set of C function calls to carry out basic functions like

- blank-check/erase/rewrite/verify of the flash
- boot cluster swapping, including definition of boot block clusters
- setting of protection flags
- obtain various information concerning the code flash memory

Detailed information how to use the library functions is given in the *Application Note "Self-Programming Library for embedded Single Voltage FLASH"* (document no. U16929EE).

The up-to-date version of the self-programming library and the above mentioned Application Note can be obtained from <u>http://www2.renesas.eu/products/micro/download/</u>.



# 7.4.3 Secure self-programming (boot cluster swapping)

The V850 flash microcontrollers support a mechanism to swap a cluster of code flash memory blocks, starting from address  $0000\ 0000_{\rm H}$ , with another cluster of the same size, located immediately above the first one.

- Boot swap cluster The cluster of blocks starting at address 0000 0000<sub>H</sub> is named active boot swap cluster, since it contains the entry point of the user's program at the default reset vector 0000 0000<sub>H</sub>.
  - **Boot swap flag** Which of the two clusters is the active boot block cluster is controlled by the boot swap flag, that can be defined during flash programming via the self-programming library.

The boot swap flag is stored in the flash memory extra area.

*Figure 7-14 on page 183* shows an example of the boot block swapping function with a cluster size of 4 flash memory blocks. After inverting the boot\_flag - it becomes not(boot\_flag) - blocks 4 to 7 become the active boot block cluster. Thus after next reset release the user's program starts from the new boot swap cluster.



Figure 7-14 Boot swap cluster swapping function



| Secure self-<br>programming | The boot cluster swapping function enables secure self-programming. In case<br>the boot code shall be rewritten, the new code can be written to the inactive<br>boot block cluster, while the boot_flag remains in its previous state.<br>If rewriting of the boot block cluster has been completed successfully, the<br>boot_flag can be inverted, making the new boot code active.<br>If rewriting of the new boot code fails for any reason, e.g. power fail or<br>unintended reset, the old boot code still remains active and rewriting can be<br>started again.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Boot block cluster          | The boot code size itself may be smaller than the boot swap cluster size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                             | The second second field is a second |

The number of flash memory blocks, which are part of the boot code, are named boot block cluster. The number of boot blocks, which are member of the cluster, can be defined during self-programming via the self-programming library.

The boot block cluster size of the V850E/PHC3 is fixed to 64 KB, i.e. it comprises 16 blocks.

Table 7-13 on page 184 shows the relation between the number of boot blocks, the boot block cluster size and the boot swap cluster.

#### Table 7-13 Relation between boot block and boot swap cluster

| Number of boot blocks | Boot block cluster                                         | Boot swap cluster                                          |  |
|-----------------------|------------------------------------------------------------|------------------------------------------------------------|--|
| 00 <sub>H</sub>       | 0000 0000 <sub>H</sub> - 0000 0FFF <sub>H</sub><br>(4 KB)  | 0000 0000 <sub>H</sub> - 0000 FFFF <sub>H</sub><br>(64 KB) |  |
| 01 <sub>H</sub>       | 0000 0000 <sub>H</sub> - 0000 1FFF <sub>H</sub><br>(8 KB)  |                                                            |  |
| 02 <sub>H</sub>       | 0000 0000 <sub>H</sub> - 0000 2FFF <sub>H</sub><br>(12 KB) |                                                            |  |
| 03 <sub>H</sub>       | 0000 0000 <sub>H</sub> - 0000 3FFF <sub>H</sub><br>(16 KB) |                                                            |  |
| 04 <sub>H</sub>       | 0000 0000 <sub>H</sub> - 0000 4FFF <sub>H</sub><br>(20 KB) |                                                            |  |
|                       |                                                            |                                                            |  |
| 07 <sub>H</sub>       | 0000 0000 <sub>H</sub> - 0000 7FFF <sub>H</sub><br>(32 KB) |                                                            |  |
| 08 <sub>H</sub>       | 0000 0000H - 0000 8FFF <sub>H</sub><br>(36 KB)             |                                                            |  |
|                       |                                                            |                                                            |  |
| 0F <sub>H</sub>       | 0000 0000 <sub>H</sub> - 0000 FFFF <sub>H</sub><br>(64 KB) |                                                            |  |
| 10 <sub>H</sub>       |                                                            |                                                            |  |
|                       | Setting                                                    | g prohibited                                               |  |
| 7F <sub>H</sub>       |                                                            |                                                            |  |

blocks

Number of boot The number of boot blocks has to be defined by the user during selfprogramming. It determines the blocks, which are subject to the boot block cluster protection, that allows to protect the boot blocks from any erase or write process.



#### Figure 7-15 on page 185 illustrates an example with following settings:

- number of boot blocks: 2 (boot block cluster contains 2 blocks), thus the active boot block cluster comprises
  - if boot\_flag: blocks 0 and 1
  - if not(boot\_flag): blocks 4 and 5
- active boot swap clusters comprises
  - if boot\_flag: blocks 0 to 3
  - if not(boot\_flag): blocks 4 to 7



#### Figure 7-15 Boot cluster swapping function

**Boot block protection** To prohibit rewriting of the boot blocks, the boot block cluster protection flag can be set during flash memory programming. When this flag is set, the blocks of the active boot block cluster can neither be erased nor written. Boot cluster swapping is impossible as well. Note that only the blocks of the active boot block cluster are protected. In the example according to *Figure 7-15 on page 185*, for instance, blocks 0 and 1 would be prohibited, while blocks 2 and 3 could still be erased and written.

- **Caution 1.** Once the boot block cluster protection has been activated, it can never be deactivated again.
  - 2. When using boot block cluster protection, do not apply the block erase function to blocks starting with or including address 00080000H. Otherwise additional flash blocks not being part of the boot block cluster itself may be protected unintentionally.

For further information concerning flash memory protection flags refer to "Data Protection and Security" on page 187.

RENESAS

# 7.4.4 Interrupt handling during flash self-programming

This V850 microcontroller provides functions to maintain interrupt servicing during the self-programming procedure.

Since neither the interrupt vector table nor the interrupt handler routines, which are normally located in the code flash memory, are accessible while self-programming is active, interrupt acknowledges have to be re-routed to non-flash memory, i.e. to the internal RAM.

Therefore two prerequisites are necessary to enable interrupt servicing during self-programming:

- The concerned interrupt handler routine needs to be copied to the internal RAM. The user has to initiate this copy process.
- The concerned interrupt acknowledge has to be re-routed to that handler. Re-routing to the handler is done by the internal firmware. Thus the user doesn't have to care about.

The internal firmware and the self-programming library provide functions to initialize and process such interrupts.

The interrupt handler routines can be copied from flash to the internal RAM by use of self-programming library functions.

The addresses of the interrupt handler routines are set up via the selfprogramming library as well.

- Note 1. Note that this special interrupt handling adds some interrupt latency time.
  - 2. Special interrupt handling is done only during the flash programming environment is activated. If self-programming is deactivated, the normal interrupt vector table in the flash memory is used.

All interrupt vectors are relocated to one entry point in the internal RAM:

- New entry point of *all* maskable interrupts is the 1st address of the internal RAM. A handler routine must check the interrupt source. The interrupt request source can be identified via the interrupt/exception source register ECR.EICC (refer to *"System register set" on page 75*)
- New entry point of *all* non maskable interrupts is the word address following the maskable interrupt entry, i.e. the second address of the internal RAM. The interrupt request source can be identified via the interrupt/exception source register ECR.FECC (refer to *"System register set" on page 75*).

In general a jump to a special handler routine will be placed at the 1st and 2nd internal RAM address, which identifies the interrupt sources and branches to the correct interrupt service routine.

The function serving the interrupt needs to be compiled as an interrupt function (i.e. terminate with a RETI instruction, save/restore all used registers, etc.).

It is recommended to read the Application Note "Self-Programming" (document no. U16929EE) for comprehensive information concerning flash selfprogramming. This document explains also the functions of the selfprogramming library. The latest version of this document can be loaded via the URL

http://www2.renesas.eu/products/micro/download



# **Chapter 8 Data Protection and Security**

# 8.1 Overview

The microcontroller supports various methods for securing safe (re-)programming of the internal flash memory and protection of the flash memory data against undesired access, such as illegal read-out or illegal reprogramming.

Security functions Security functions enhance the reliability of the flash operation during normal operation and support countermeasures against unexpected failures during reprogramming processes. These are basically:

- Secure self-programming
- Secure bootloader update
- Boot block cluster protection

These functions are described in detail in "Flash Memory" on page 159.

Protection functions

Protection functions provide a set of mechanisms to protect the internal flash
 memory data from being read, erased or altered by unauthorized persons.
 These are basically:

- On-chip debug interface (N-Wire) protection
- Flash memory erase/write/read protection via the serial programming interface

Certain interfaces offer access to the internal flash memory: N-Wire debug interface, external flash programmer interfaces and self-programming facilities. All of these interfaces need to be considered for a proper protection concept.

The following sections give an overview about supported protection methods.

# 8.2 N-Wire Debug Interface Protection

In general, read-out of the flash memory contents is possible via the N-Wire debug interface, but protection against illegal read-out can be enabled. For protection of the flash memory, the usage of the debug interface can be protected and it can be disabled. The debug interface is protected via a 10-byte ID code and an internal flag (N-Wire use enable flag).

When the debugger is started, the status of a flag is queried (N-Wire use enable flag). Set this flag to zero to disable the use of the N-Wire in-circuit emulator.

When debugging is enabled (N-Wire use enable flag is set), you have to enter a 10-byte ID code via the debugger. The code is compared with the ID code stored in the internal flash memory. If the codes do not match, debugging is not possible.

The N-Wire use enable flag can be set or reset while reprogramming the flash by an external flash writer or with the self-programming feature. The flag is located at bit 7 at address 0000  $0079_{\rm H}$ .

You can specify your own 10-byte ID code and program it to the internal flash memory by an external flash writer or with the self-programming feature. The ID code is located in the address range  $0000\ 0070_{\rm H}$  to  $0000\ 0079_{\rm H}$ .



The protection levels are summarized in Table 8-1

| Table 8-1 | Possible results of ID code comparison |
|-----------|----------------------------------------|
|-----------|----------------------------------------|

| N-Wire use enable flag | ID code                             | Protection Level                                                                                                                                                         |
|------------------------|-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                      | X <sup>a</sup>                      | Level 2:<br>Full protection<br>N-Wire debug interface cannot be used. <sup>b</sup>                                                                                       |
| 1                      | user-specific<br>ID code            | Level 1:<br>ID code protection user ID code<br>N-Wire debug interface can only be used<br>if the user enters the correct ID code.                                        |
|                        | ID code is all<br>ones <sup>c</sup> | Level 0:<br>ID code protection with default ID code<br>N-Wire debug interface can be used if the<br>user enters the default ID code FF <sub>H</sub> for all<br>ID bytes. |

a) Codes are not compared

b) Once the N-Wire debug interface has been set as "use-prohibited", it cannot be used until the flash memory is re-programmed.

- c) This is the default state after the flash memory has been erased.
- **Note** 1. After you have set protection levels 1 or 2, set the "block erase disable flag" in the flash extra area. Otherwise, an unauthorized person could erase the block that contains the ID code or the "N-Wire use enable flag", respectively, and thus suspend the protection.
  - 2. If an unauthorized user tries to find out the 10-byte ID by comparing all possible ID codes, this will take up to  $3.83 \times 10^8$  years at 100 MHz.



# 8.3 Flash Programmer and Self-Programming Protection

In general, illegal read-out and re-programming of the flash memory contents is possible via the flash writer interface and the self-programming feature. For protection of the flash memory, the set of flags which can be set by the user, provide various protection levels.

- Serial programming It is possible to prohibit any access from external via the serial programming interface, e.g. by an external flash programmer. With maximum protection the internal flash memory can not be erased, read-out or written at all, neither in block units nor the entire flash memory.
  - **Self-programming** During self-programming all operations to erase, read or program the flash memory is under control of the user's program. Thus no further protection functions in self-programming mode are considered. One exception is the boot block protection, which applies also in self-programming mode.

Protection flags The protection flags can be set respectively reset by an external flash programmer, provided the effective protection level allows to do so. In self-programming mode the effective protection flags can not be reset, but other ones can be set to enhance the protection level. The protection flags are stored in the flash memory extra area.

Each protection function can be used in combination with the others at the same time.

# (1) Write protection flag

Set this flag to disable the write function via external flash programmer interfaces.

No flash memory content can be written from external, if this flag is set. Erasure of single blocks is prohibited as well.

This flag does not affect the self-programming interface. In self-programming mode writing of the flash memory is further on possible.

# (2) Chip erase protection flag

Set this flag to disable the chip erase function via external flash programmer interfaces.

No flash memory content can be erased - neither in single blocks nor the entire flash memory - from external, if this flag is set.

Chip erase is not available in self-programming mode, though it is possible to erase the entire flash memory content by block erase of all blocks all together. Note that the contents of the extra area is not erased by this means. I.e. protection flags, etc. are still valid.

# (3) Block erase protection flag

Set this flag to disable the feature to erase single blocks via external flash programmer interfaces.

Single blocks can not be erased. Chip erase is still possible, provided the chip erase protection flag is not set.

This flag does not affect the self-programming interface. In self-programming mode erasure of single blocks or sets of contiguous blocks of the flash memory is further on possible.



#### (4) Read-out protection flag

Set this flag to disable the feature that allows reading back the flash memory via the serial programming interfaces. No flash content can be read out.

This flag does not affect the self-programming interface. In self-programming mode read-out of flash memory content is further on possible.

# (5) Boot block cluster protection flag

Set this flag to disable erasure and rewrite of the boot block cluster. The boot block cluster can not be manipulated in any way (no erase/write).

This applies in serial and self-programming mode.

Once this flag is set, it is impossible to reset this flag. Thus the boot block cluster content can not be changed any more.

For the explanation of the boot block cluster refer to *"Secure self-programming (boot cluster swapping)" on page 183.* 

All protection flags are reset after shipment of the device, thus no protection is enabled at all.

Once a protection flag has been set, i.e. the protection is effective, it can not be reset by any means, except after a chip erase, which erases the entire flash memory including the extra area.

Consequently without prior chip erase the protection level can only be increased, but not decreased.

| Function                                    | Functional outline                                                                                                                                                                               | Applicable<br>(√: applies, ×: doesn't apply) |                  |
|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|------------------|
| Function                                    |                                                                                                                                                                                                  | Serial programming                           | Self-programming |
| Block erase<br>command prohibit             | Erasure of single blocks impossible.<br>Once block erase protection is enabled,<br>disable is only possible after chip erase.                                                                    | $\checkmark$                                 | ×                |
| Chip erase<br>command prohibit              | Erasure of the entire flash (including the extra<br>area) or single blocks impossible.<br>Once chip erase protection is enabled, all<br>protection flag settings can not be changed<br>any more. | V                                            | ×                |
| Program command prohibit                    | Erasure and rewrite of single blocks<br>impossible.<br>Once write protection is enabled, disable is<br>only possible after chip erase.                                                           | $\checkmark$                                 | ×                |
| Read command prohibit                       | Read-out of any flash content impossible.<br>Once read protection is enabled, disable is<br>only possible after chip erase.                                                                      | V                                            | ×                |
| Rewriting boot<br>block cluster<br>prohibit | Erasure (by block or chip erase) or writing of<br>the boot block cluster impossible.<br>Once rewrite protection of the boot block<br>cluster is enabled, it can not be disabled any<br>more.     | V                                            | V                |

#### Table 8-2 Protection functions overview



|                      |                    |                    | Block        | erasure              |                 | Wr           | ite                  |
|----------------------|--------------------|--------------------|--------------|----------------------|-----------------|--------------|----------------------|
| Pro                  | phibition state    | Programming mode   | Boot<br>area | None<br>boot<br>area | Chip<br>erasure | Boot<br>area | None<br>boot<br>area |
| Rewriting            | All enabled        | Self-programming   | ye           | es                   | _               | ye           | es                   |
| boot area<br>enabled |                    | Serial programming | ye           | es                   | yes             | ye           | es                   |
| 0.100.000            | Block erase        | Self-programming   | ye           | es                   | -               | ye           | es                   |
|                      | command prohibited | Serial programming | n            | 0                    | yes             | ye           | es                   |
|                      | Chip erase command | Self-programming   | ye           | yes                  |                 | yes          |                      |
|                      | prohibited         | Serial programming | no           |                      | no              | yes          |                      |
|                      | Write command      | Self-programming   | ye           | es                   | -               | ye           | es                   |
|                      | prohibited         | Serial programming | n            | 0                    | yes             | n            | 0                    |
| Rewriting            | All enabled        | Self-programming   | no           | yes                  | -               | no           | yes                  |
| boot area prohibited |                    | Serial programming |              | yes                  | no              |              | yes                  |
| promotou             | Block erase        | Self-programming   |              | yes                  | -               |              | yes                  |
|                      | command prohibited | Serial programming |              | no                   | yes             |              | yes                  |
|                      | Chip erase command | Self-programming   |              | yes                  | _               |              | yes                  |
|                      | prohibited         | Serial programming |              | no                   | no              |              | yes                  |
|                      | Write command      | Self-programming   |              | yes                  | -               |              | yes                  |
|                      | prohibited         | Serial programming |              | no                   | yes             |              | no                   |

 Table 8-3
 Rewriting operation when erasing/writing is enabled/prohibited

Note -: not supported

# Table 8-4 Read operation when reading is enabled/prohibited

| Prohibition State       | Programming mode   | Read |
|-------------------------|--------------------|------|
| Read command enabled    | Self-programming   |      |
|                         | Serial programming |      |
| Read command prohibited | Self-programming   |      |
|                         | Serial programming | ×    |

Note  $\sqrt{\cdot}$  execution enabled,  $\times$ : execution disabled, -: not supported



# Chapter 9 Bus and Memory Control (BCU, MEMC)

The Bus Control Unit BCU and Memory Controller MEMC within V850E/PHC3 control the access to the on-chip peripherals as well as to the data flash memory.

# 9.1 Overview

Features summary The bus and memory control of the microcontroller device provides:

- Access to the on-chip peripherals via the peripheral bus (NPB)
- Access to the DATA-CRC unit and the data flash memory via the memory controller



# 9.1.1 Description

The figure below shows a block diagram of the modules that are necessary for accessing on-chip peripherals.



Figure 9-1 Bus and Memory Control block diagram

Busses The busses are abbreviated as follows:

- NPB: Peripheral bus
- VSB: V850 system bus
- VDB: V850 data bus
- VFB: V850 fetch bus
- **BCU** The Bus Control Unit (BCU) controls the access to on-chip peripherals.

For access to the data flash memory and the Data CRC unit , the BCU generates the necessary control signals (chip select signals) for the Memory Controller.

**Memory Controller** The Memory Controller generates the control signals for access to the DATA-CRC unit and the data flash. For example, it generates the read strobe  $(\overline{\text{RD}})$  and the write strobe  $(\overline{\text{WR}})$ .

This product does not provide any signals of the Memory Controller externally.



# 9.1.2 Memory areas/banks and chip select signals

This product does not provide any signals of the Memory Controller externally. Therefore MEMC chip select, address, data, read/write or wait signals are not available.

This section is describing the memory area set-up and the chip select implementation. Further configuration is needed for the dedicated chip select areas to make use of the data flash and the CRC unit which are attached to the memory controller.

The 256 MB address range is divided into the 64 MB areas 0 to 3 (see *Figure 9-2 on page 195*).

The chip select signals  $\overline{CS1}$ ,  $\overline{CS3}$ ,  $\overline{CS4}$ ,  $\overline{CS6}$  are fixed assigned to these areas.

Memory areas 0 and 3 are further subdivided into

- four 2 MB memory banks (banks 0 to 3, respectively 12 to 15), for which the chip select signals CS0, CS2, CS5, CS7 are fixed assigned.
- the remaining 56 MB

Chip select area

area The memory area that activates the same chip select signal is called chip select area.

Note Throughout this chapter, the individual chip select signals are identified by "k" (k = 1, 7).





Figure 9-2 Memory areas/banks and chip select signals



- **Note 1.** The shown base address 0840 0000H of the programmable peripheral area assumes thePeripheral area selection control register BPC = A100H.
  - 2. Access to memory areas others than the shown user memory areas is forbidden.



# 9.1.3 Peripheral I/O areas

Two areas of the address range are reserved for the registers of the on-chip peripheral functions. These areas are called "peripheral I/O areas":

# Table 9-1Peripheral I/O areas

| Name                                      | Address range                                                                            | Size  |
|-------------------------------------------|------------------------------------------------------------------------------------------|-------|
| Fixed peripheral I/O area                 | 0FFF F000 <sub>H</sub> to 0FFF FFFF <sub>H</sub>                                         | 4 KB  |
| Programmable peripheral<br>I/O area (PPA) | Can be allocated at arbitrary addresses.<br>Base address is defined in the BPC register. | 16 KB |

# (1) Fixed peripheral I/O area

The fixed peripheral I/O area holds the registers of the on-chip peripheral I/O functions.

Access timing During a read or write access the CPU operation stops until the access via the NPB is completed.

**Note** Because the address space covers 256 MB, the address bits A[31:28] are not considered. Therefore, in this manual, all addresses of peripheral I/O registers in the 4 KB peripheral I/O area are given in the range FFFF  $F000_H$  to FFFF FFFF<sub>H</sub> instead of 0FFF  $F000_H$  to 0FFF FFFF<sub>H</sub>.

# (2) Programmable peripheral I/O area (PPA)

The usage and the address range of the PPA is configurable. The PPA extends the fixed peripheral I/O area and assigns an additional 12 KB address space for accessing on-chip peripherals.

The figure below illustrates the programmable peripheral I/O area (PPA).



Figure 9-3 Programmable peripheral I/O area

The CAN modules registers and message buffers are allocated to the PPA. Refer to *"CAN module register and message buffer addresses" on page 393* for information how to calculate the register and message buffer addresses of the CAN modules.

Access timing During a read access the CPU operation stops until the read access via the NPB is completed.

RENESAS

During a write access the CPU operation continues operation, provided any preceded NPB access is already finished. If a preceded NPB access is still ongoing the CPU stops until this access is finished and the NPB is cleared.

**Caution 1.** If the programmable peripheral I/O area overlaps one of the following areas, the programmable peripheral I/O area becomes ineffective:

- Peripheral I/O area
- ROM area
- RAM area
- 2. The *fixed* peripheral I/O area is mirrored to the upper 4 KB of the *programmable* peripheral I/O area regardless of the base address of the PPA. Access to this mirror of the *fixed* peripheral I/O area is prohibited.
- Note All address definitions in this manual that refer to the programmable peripheral area assume that the base address of the PPA is  $840\ 0000_{\text{H}}$ , that means BPC =  $A100_{\text{H}}$ .



# 9.1.4 Data flash access

The on-chip data flash is accessed by the memory controller, which requires certain settings. The data flash is fixed assigned to  $\overline{CS1}$ , the memory controller options must be configured accordingly.

*Table 9-2* shows all required register settings for the data flash's chip select signal  $\overline{CS1}$ . Some settings are appropriate for the data flash per default, others must be changed before the first access to the data flash.

For details about the control settings refer to the description of the registers.

| Control bit          | Required setting | Comment                                                                           |
|----------------------|------------------|-----------------------------------------------------------------------------------|
| BCT0.ME1             | 1                | <ul> <li>enable CS1</li> <li>no default, must be changed</li> </ul>               |
| AWC.AHW1<br>AWC.ASW1 | 00 <sub>B</sub>  | <ul><li>no address setup/hold waits</li><li>no default, must be changed</li></ul> |
| DWC0.DWC1[2:0]       | 001 <sub>B</sub> | <ul><li> 1 data wait state</li><li> no default, must be changed</li></ul>         |
| BCC.BC11             | 0                | <ul><li>no idle states</li><li>no default, must be changed</li></ul>              |

### Table 9-2 Register settings for data flash access

Base address The base address of the data flash is 03E0 0000<sub>H</sub>.



# 9.1.5 CRC module access

The on-chip Data-CRC module is accessed by the memory controller, which requires certain settings. The DATA-CRC unit is fixed assigned to  $\overline{CS7}$ , the memory controller options must be configured accordingly.

*Table 9-3* shows all required register settings for the CRC module's chip select signal  $\overline{CS7}$ . Some settings are appropriate for the CRC module per default, others must be changed before the first access to the CRC module.

For details about the control settings refer to the description of the registers.

| Control bit          | Required setting | Comment                                                                           |
|----------------------|------------------|-----------------------------------------------------------------------------------|
| BCT1.ME7             | 1                | <ul> <li>enable CS7</li> <li>no default, must be changed</li> </ul>               |
| AWC.AHW7<br>AWC.ASW7 | 00 <sub>B</sub>  | <ul><li>no address setup/hold waits</li><li>no default, must be changed</li></ul> |
| DWC1.DWC7[2:0]       | 000 <sub>B</sub> | <ul><li>no data wait states</li><li>no default, must be changed</li></ul>         |
| BCC.BC71             | 0                | <ul><li>no idle states</li><li>no default, must be changed</li></ul>              |

 Table 9-3
 Register settings for CRC module access

Base address The base address of the CRC module is 0FE0 0000<sub>H</sub>.



# 9.1.6 Boundary operation conditions

The microcontroller device has the following boundary operation conditions:

#### (1) Program space

Instruction fetches from the internal peripheral I/O area are inhibited and yield NOP operations.

If a branch instruction exists at the upper limit of the internal RAM area, a prefetch operation (invalid fetch) that straddles over the internal peripheral I/O area does not occur.

#### (2) Data space

The microcontroller device is provided with an address misalign function.

By this function, data of any format (word: 32 bit, halfword: 16 bit, byte: 8 bit) can be placed to any address in memory, even though the address is not aligned to the data format (that means address 4n for words, address 2n for halfwords).

- Unaligned halfword data access
   When the LSB of the address is A0 =1, two byte accesses are performed.
- Unaligned word data access
   When the LSB of the address is A0 =1, two byte and one halfword accesses are performed. In total it takes 3 bus cycles.
  - When the LSBs of the address are A[1:0] =10<sub>B</sub>, two halfword accesses are performed.
- **Note** Accessing data on misaligned addresses takes more than one bus cycle to complete data read/write. Consequently, the bus efficiency will drop.



# 9.1.7 Initializing access to the Data flash memory and the CRC module

To enable access to the on-chip Data flash memory and the on-chip Data-CRC module, initialize the following registers after any reset.

- Bus cycle configuration registers BCTn Set BCT0 to 44C4<sub>H</sub> and BCT1 to C444<sub>H</sub>.
- Data wait control registers DWCn Set DWC0 to 7717<sub>H</sub> and DWC1 to 0777<sub>H</sub>.
- Bus cycle configuration register BCC Set BCC to 2AA2<sub>H</sub>.
- Address wait control register AWC Set AWC to 3FF3<sub>H</sub>.
- 5. Control register DVC Specify the frequency of the bus clock BCLK (e.g. to  $00_{H}$  for BCLK = fxx/2).
- **Caution** 1. Do not change these registers after initialization.
  - 2. Do not access the memory controller controlled areas before initialization is finished.



# 9.2 Registers

Access to on-chip peripherals is controlled and operated by registers of the Bus Control Unit (BCU) and the Memory Controller:

| Table 9-4 | Bus and memory control register overview |   |
|-----------|------------------------------------------|---|
|           |                                          | _ |

| Module                   | Register name                                      | Shortcut | Address                |
|--------------------------|----------------------------------------------------|----------|------------------------|
| Bus Control Unit (BCU)   | Peripheral area selection control register         | BPC      | FFFF F064 <sub>H</sub> |
|                          | Internal peripheral function wait control register | VSWC     | FFFF F06E <sub>H</sub> |
| Memory Controller (MEMC) | Bus cycle configuration registers                  | BCT0     | FFFF F480 <sub>H</sub> |
|                          |                                                    | BCT1     | FFFF F482 <sub>H</sub> |
|                          | Address wait control register                      | AWC      | FFFF F488 <sub>H</sub> |
|                          | Data wait control registers                        | DWC0     | FFFF F484 <sub>H</sub> |
|                          |                                                    | DWC1     | FFFF F486 <sub>H</sub> |
|                          | Bus cycle control register                         | BCC      | FFFF F48A <sub>H</sub> |
|                          | Bus clock dividing frequency control register      | DVC      | FFFF F48E <sub>H</sub> |



# 9.2.1 BCU registers

The following registers are part of the BCU. They define the data bus width, the endian format of word data, and they control access to external devices.

### (1) BPC - Peripheral area selection control register

The 16-bit BPC register defines whether the programmable peripheral I/O area (PPA) is used or not and determines the starting address of the PPA.

Access This register can be read/written in 16-bit units.

Address FFFF F064<sub>H</sub>

Initial Value 0000<sub>H</sub>

| 15   | 14 | 13   | 12   | 11   | 10   | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------|----|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| PA15 | 0  | PA13 | PA12 | PA11 | PA10 | PA9 | PA8 | PA7 | PA6 | PA5 | PA4 | PA3 | PA2 | PA1 | PA0 |

#### Table 9-5 BPC register contents

| Bit Position | Bit Name | Function                                                                                                              |  |  |  |  |  |  |  |  |  |
|--------------|----------|-----------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| 15           | PA15     | Select usage of programmable peripheral I/O area (PPA).<br>0: PPA disabled<br>1: PPA enabled                          |  |  |  |  |  |  |  |  |  |
| 13 to 0      | PA[13:0] | Bits PA[13:0] specify bits 27 to 14 of the starting address of the PPA. The other bits of the address are fixed to 0. |  |  |  |  |  |  |  |  |  |

Caution The bits marked with 0 must always be 0. The base address PBA of the programmable peripheral area sets the start address of the 16 KB PPA in a range of 256 MB. The 256 MB page is mirrored 16 times to the entire 32-bit address range.

The base address PBA is calculated by

 $PBA = BPC.PA[13:0] \times 2^{14}$ 

*Table 9-6* shows how the addresses of the programmable peripheral area are assembled. The base address PBA is highlighted.

#### Table 9-6 Address range of programmable peripheral area (16 KB)

| 31 | <br>28 | 27 |              | 14 | 13 | <br>1 | 0 | bit |
|----|--------|----|--------------|----|----|-------|---|-----|
| 0  | <br>0  |    | BPC.PA[13:0] |    | 1  | <br>1 | 1 |     |
|    |        |    |              |    |    | <br>  |   | -   |
| 0  | <br>0  |    | BPC.PA[13:0] |    | 0  | <br>0 | 1 |     |
| 0  | <br>0  |    | BPC.PA[13:0] |    | 0  | <br>0 | 0 | PBA |

**Note** The recommended setting for the BPC register is  $A100_{H}$ . With this configuration the programmable peripheral area is mapped to the address range  $0840\ 0000_{H}$  to  $0840\ 3FFF_{H}$ . With this setting the CAN message buffer registers are accessible via the addresses given in *"CAN Controller (CAN)" on page 368*.



# (2) VSWC - Internal peripheral function wait control register

The 8-bit VSWC register controls the bus access wait for the on-chip peripheral I/O registers.

Access to on-chip peripheral I/O registers is made in 3 clocks (without wait), however, waits may be required depending on the operation frequency. Set the values described below to the VSWC register in accordance with the operation frequency used.

For DMA transfers, the bus access wait and signal timing is controlled by registers DMAWC0 and DMAWC1. For a description of these registers see *"DMA Functions (DMA Controller)" on page 211.* 

Access This register can be read/written in 8-bit or 1-bit units.

Address FFFF F06E<sub>H</sub>

Initial Value 77<sub>H</sub>

VSWC must be initialized after  $\overline{\text{RESET}}$  according to below setting: VSWC = 24<sub>H</sub>



# 9.2.2 Memory Controller registers

The following registers are part of the Memory Controller. They specify the number of data wait states, the number of address wait states, and the number of idle states.

### (1) BCTn - Bus cycle configuration registers

The 16-bit BCTn registers enable the operation of the Memory Controller for each chip select signal.

Access These registers can be read/written in 16-bit units.

| Address | BCT0: FFFF F480 <sub>H</sub> |
|---------|------------------------------|
|         | BCT1: FFFF F482 <sub>H</sub> |

Initial Value 4444<sub>H</sub>

These registers must be initialized as follows:

Set BCT0 to  $44C4_{H}$  and BCT1 to  $C444_{H}$ ..

BCT0

| 15   | 14  | 13 | 12 | 11  | 10        | 9 | 8   | 7   | 6 | 5 | 4 | 3   | 2 | 1 | 0 |
|------|-----|----|----|-----|-----------|---|-----|-----|---|---|---|-----|---|---|---|
| 0    | 1   | 0  | 0  | 0   | 1         | 0 | 0   | ME1 | 1 | 0 | 0 | 0   | 1 | 0 | 0 |
| CS3  |     |    |    | CS  | <u>S2</u> |   | CS1 |     |   |   |   | CS0 |   |   |   |
|      |     |    |    |     |           |   |     |     |   |   |   |     |   |   |   |
| BCT1 |     |    |    |     |           |   |     |     |   |   |   |     |   |   |   |
| 15   | 14  | 13 | 12 | 11  | 10        | 9 | 8   | 7   | 6 | 5 | 4 | 3   | 2 | 1 | 0 |
| ME7  | 1   | 0  | 0  | 0   | 1         | 0 | 0   | 0   | 1 | 0 | 0 | 0   | 1 | 0 | 0 |
|      | CS7 |    |    | CS6 |           |   |     | CS5 |   |   |   | CS4 |   |   |   |

### Table 9-7 BCTn register contents

| <b>Bit Position</b> | Bit Name | Function                                                                                                                 |
|---------------------|----------|--------------------------------------------------------------------------------------------------------------------------|
| BCT0: 7<br>BCT1: 11 | MEk      | Enables/disables Memory Controller operation for<br>chip select area k.<br>0: Operation disabled<br>1: Operation enabled |

#### Caution

1. The bits marked with 0 must always be 0.

2. The bits marked with 1 must always be 1.

3. To initialize the memory controller after a reset, registers BCTn have to be set. Do not change this register after initialization. Do not access the memory controller controlled areas before initialization is finished.



#### (2) AWC - Address wait control register

The 16-bit AWC register controls the insertion of an address setup wait and address hold wait state before and after the T1 cycle. The address setup wait and address hold wait state can be enabled for each chip select area.

Access This register can be read/written in 16-bit units.

Address FFFF F488<sub>H</sub>

Initial Value FFFF<sub>H</sub>: After system setup, by default, address hold and wait states insertion is enabled for each chip select area.

This register must be initialized as follows:

Set AWC to 3FF3<sub>H</sub>.

| 15   | 14     | 13 | 12 | 11 | 10 | 9 | 8  | 7 | 6  | 5 | 4  | 3    | 2    | 1  | 0  |
|------|--------|----|----|----|----|---|----|---|----|---|----|------|------|----|----|
| AHW7 | ' ASW7 | 1  | 1  | 1  | 1  | 1 | 1  | 1 | 1  | 1 | 1  | AHW1 | ASW1 | 1  | 1  |
| C    | S7     | C  | S6 | C  | S5 | C | S4 | C | S3 | C | S2 | C    | S1   | CS | S0 |

| Table 9-8 | AWC register contents |
|-----------|-----------------------|
|-----------|-----------------------|

| Bit position | Bit name | Function                                                                                                                                                         |  |  |  |  |  |  |  |  |
|--------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| 3, 15        | AHWk     | Enables/disables the address hold wait insertion for chip select areas<br>0: No wait state inserted<br>1: Address hold wait state inserted after T1 bus cycle    |  |  |  |  |  |  |  |  |
| 2, 14        | ASWk     | Enables/disables the address setup wait insertion for chip select areas<br>0: No wait state inserted<br>1: Address setup wait state inserted before T1 bus cycle |  |  |  |  |  |  |  |  |

**Caution** To initialize the memory controller after a reset, register AWC has to be set. Do not change this register after initialization. Do not access the memory controller controlled areas before initialization is finished.

**Note** For access to Code Flash, iRAM and peripheral I/O areas, which are not controlled by the MEMC, programmable waits are *not* carried out.



#### (3) DWCn - Data wait control registers

The 16-bit DWCn registers control the number of data wait states after the first access cycle (T1). Each chip select area is controlled separately. A maximum of seven data wait states is possible.

Access This register can be read/written in 16-bit units.

Address DWC0: FFFF F484<sub>H</sub> DWC1: FFFF F486<sub>H</sub>

Initial Value 7777<sub>H</sub>: After system setup, by default, seven data wait states are inserted for each chip select area.

These registers must be initialized as follows:

Set DWC0 to  $7717_{H}$  and DWC1 to  $0777_{H}$ .

DWC0

| 15 | 14                    | 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6    | 5    | 4    | 3 | 2 | 1 | 0 |
|----|-----------------------|----|----|----|----|---|---|----|------|------|------|---|---|---|---|
| 0  | 1                     | 1  | 1  | 0  | 1  | 1 | 1 | 0  | DW12 | DW11 | DW10 | 0 | 1 | 1 | 1 |
|    | <u>CS3</u> <u>CS2</u> |    |    |    |    |   |   | CS | S1   |      | CS0  |   |   |   |   |

DWC1

| 15 | 14      | 13   | 12   | 11 | 10 | 9 | 8 | 7 | 6  | 5 | 4   | 3 | 2 | 1 | 0 |
|----|---------|------|------|----|----|---|---|---|----|---|-----|---|---|---|---|
| 0  | DW72    | DW71 | DW70 | 0  | 1  | 1 | 1 | 0 | 1  | 1 | 1   | 0 | 1 | 1 | 1 |
|    | CS7 CS6 |      |      |    |    |   |   | C | S5 |   | CS4 |   |   |   |   |

| Table 9-9 | DWCn | register | contents |
|-----------|------|----------|----------|
|-----------|------|----------|----------|

| Bit position     | Bit name | Function                                                                            |                                |  |  |  |
|------------------|----------|-------------------------------------------------------------------------------------|--------------------------------|--|--|--|
|                  |          | Sets the number of wait states after the first access cycle (T1) for chip se areas. |                                |  |  |  |
|                  |          | DWk[2:0]                                                                            | Number of inserted wait states |  |  |  |
| DWOO             |          | 000 <sub>B</sub>                                                                    | No wait state inserted         |  |  |  |
| DWC0:<br>4, 5, 6 |          | 001 <sub>B</sub>                                                                    | 1 wait state                   |  |  |  |
| DWC1:            |          | 010 <sub>B</sub>                                                                    | 2 wait states                  |  |  |  |
| 12, 13, 14       |          | 011 <sub>B</sub>                                                                    | 3 wait states                  |  |  |  |
|                  |          |                                                                                     |                                |  |  |  |
|                  |          | 111 <sub>B</sub>                                                                    | 7 wait states                  |  |  |  |
|                  |          |                                                                                     |                                |  |  |  |

Caution 1. The bits marked with 0 must always be 0.

2. To initialize the memory controller after a reset, registers DWCn have to be set. Do not change these registers after initialization. Do not access the memory controller controlled areas before initialization is finished.

**Note** For access to Code Flash, iRAM and peripheral I/O areas, which are not controlled by the MEMC, programmable waits are *not* carried out.



| (4)                                                       | BCC - Bus cy                                   | ycle cont          | rol regist | ər      |                 |        |        |    |                 |    |
|-----------------------------------------------------------|------------------------------------------------|--------------------|------------|---------|-----------------|--------|--------|----|-----------------|----|
|                                                           | The 16-bit BC <ul> <li>insertion of</li> </ul> | 0                  |            |         | •               |        | t area |    |                 |    |
| Access This register can be read/written in 16-bit units. |                                                |                    |            |         |                 |        |        |    |                 |    |
| Address                                                   | FFFF F48A <sub>H</sub>                         |                    |            |         |                 |        |        |    |                 |    |
| Initial Value                                             | AAAA <sub>H</sub> : After<br>These registe     | •                  |            |         |                 | erted. |        |    |                 |    |
|                                                           | Set BCC to 2                                   | AA2 <sub>H</sub> . |            |         |                 |        |        |    |                 |    |
| 15 14 13 12                                               | 11 10                                          | 9                  | 8 7        | 6       | 5               | 4      | 3      | 2  | 1               | 0  |
| BC71 0 1 0                                                | 1 0                                            | 1                  | 0 1        | 0       | 1               | 0      | BC11   | 0  | 1               | 0  |
| CS7 CS6                                                   | CS5                                            | CS4                | C          | S3      | CS              | 32     | CS     | 51 | CS              | 30 |
| BC71 0 1 0                                                | 1 0                                            | 1<br>CS4           | 0 1        | 0<br>S3 | 1<br><u>C</u> S | 0      | BC11   | 0  | 1<br><u>C</u> S | 0  |

Note The default value 0 of bits 14, 12, 10, 8, 6, 4, 0 and 0 must not be changed.

| Table 9-10 | BCC register of | contents |
|------------|-----------------|----------|
|------------|-----------------|----------|

| Bit position | Bit name | Function                                                                                                                                                               |
|--------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3, 15        | BCk1     | Enables/disables the idle state insertion after any read access for chip select<br>areas.<br>0: No idle state inserted<br>1: Idle state inserted after any read access |

**Caution** To initialize the memory controller area after a reset, register BCC has to be set. Do not change this register after initialization. Do not access the memory controller controlled areas before initialization is finished.

**Note** For access to Code Flash, iRAM and peripheral I/O areas, which are not controlled by the MEMC, *no* idle states are inserted.



# (5) DVC - Bus clock dividing frequency control register

The 8-bit DVC register controls

- idle state inserted after any write access
- the frequency of the bus clock BCLK

Access This register can be read/written in 8-bit units.

Address FFFF F48E<sub>H</sub>

Initial Value 00<sub>H</sub>.

|   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0    |
|---|-----|-----|-----|-----|-----|-----|-----|------|
|   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | DVC0 |
| _ | R/W  |

| Bit position | Bit name | Function                                                                                       |
|--------------|----------|------------------------------------------------------------------------------------------------|
| 0            | DVC0     | Specifies the frequency of the bus clock BCLK.<br>0: BCLK = $f_{XX}/2$<br>1: BCLK = $f_{XX}/4$ |

Caution 1. The bits marked with 0 must always be 0.

- 2. To initialize the memory controller after a reset, register DVC has to be set. Do not change this register after initialization. Do not access the memory controller controlled areas before initialization is finished.
- **Note** For access to Code Flash, iRAM and peripheral I/O areas, which are not controlled by the MEMC, *no* idle states are inserted.



# Chapter 10 DMA Functions (DMA Controller)

The microcontroller includes a Direct Memory Access Controller (DMAC) that executes and controls DMA transfers.

**Note** Throughout this chapter, the individual channels of the DMA Controller are identified by "n" (n = 0 to 7)

# 10.1 Overview

The DMAC controls data transfer between internal RAM and I/O, based on DMA requests issued by the on-chip peripheral I/O.

Features summary The DMAC has the following features:

- 8 independently configurable channels
- Programmable access wait and signal timing
- Maximum DMA transfer count: 256 (2<sup>8</sup>)
- **Caution** If the RAM error correction function is disabled, DMA operation is prohibited. Thus disable all DMA channels in that case.

# 10.1.1 Principle of operation

A DMA transfer essentially transfers a predefined number of data units between the internal RAM (iRAM) and peripheral I/O registers. The CPU initiates the transfer and the transfer itself is performed by the DMAC.

**DMA channels** Each DMA channel has a fixed transfer direction to transfer data between the internal RAM and a peripheral I/O register:

- DMA channels 0, 1, 4, 5: I/O  $\rightarrow$  iRAM
- DMA channels 2, 3, 6, 7: iRAM  $\rightarrow$  I/O
- **DMA priorities** The DMA channel priorities are fixed as follows: ch.0 > ch.1 > ch.2 > ch.3 > ch.4 > ch.5 > ch.6 > ch.7
- Transfer data units The size of a data unit to be transferred is either 8 bit or 16 bit:
  - DMA channels 0 to 3: 16 bit
  - DMA channels 4 to 7: 8 bit or 16 bit selectable
- Transfer addresses For a DMA transfer, the following addresses have to be defined:
  - Source address: address of data to be copied



|                     | The source address depends on the DMA channel:                                                                                                                                                                                                         |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | <ul> <li>DMA channels n = 0, 1: implicitly defined fixed ADC registers</li> </ul>                                                                                                                                                                      |
|                     | <ul> <li>DMA channels n = 4, 5: implicitly defined fixed CSIB, CSIE, UARTC data<br/>receive register</li> </ul>                                                                                                                                        |
|                     | <ul> <li>DMA channels n = 2, 3, 6, 7: iRAM start address, defined by MARn<br/>registers</li> </ul>                                                                                                                                                     |
|                     | <ul> <li>Destination address: address to store the data to<br/>The destination address depends on the DMA channel:</li> </ul>                                                                                                                          |
|                     | <ul> <li>DMA channels n = 0, 1, 4, 5: iRAM start address, defined by MARn<br/>register</li> </ul>                                                                                                                                                      |
|                     | - DMA channels n = 2, 3: Timer S start register address, defined by SARn                                                                                                                                                                               |
|                     | <ul> <li>DMA channels n = 6, 7: implicitly defined fixed CSIB, CSIE, UARTC data<br/>transmit registers</li> </ul>                                                                                                                                      |
|                     | Depending on the transfer data unit, source start addresses or destination start addresses are automatically incremented after each data transfer:                                                                                                     |
|                     | <ul> <li>8-bit data: address increment by 1</li> <li>16-bit data: address increment by 2</li> </ul>                                                                                                                                                    |
| Transfer start/stop | The DMA transfer is initiated by defined interrupts of the on-chip peripheral I/Os. These interrupts are called DMA triggers.                                                                                                                          |
|                     | To start a DMA transfer, the following conditions have to be fulfilled:                                                                                                                                                                                |
|                     | <ul> <li>DMA transfer is enabled (DMAMCL.DEn = 1).</li> <li>The number of transfer actions that has to be performed (transfer count) is</li> </ul>                                                                                                     |
|                     | written to register DTRCn.                                                                                                                                                                                                                             |
|                     | <ul> <li>The transfer status is set to "idle" (DMASL.DMASn = 0).</li> <li>DMA trigger is generated.</li> </ul>                                                                                                                                         |
|                     | When the defined number of transfer actions is completed, a DMA completion interrupt (INTDMAn) is generated and the DMA transfer is stopped.                                                                                                           |
| Transfer status     | <ul> <li>The transfer status can be monitored:</li> <li>Register DMASL displays the transfer status (idle/in progress/completed).</li> <li>Register DTCRn displays the current transfer count (it is decreased with every transfer action).</li> </ul> |
| 10.1.2              | Forcible termination of DMA transfer                                                                                                                                                                                                                   |
|                     | A once started DMA transfer can be forcible terminated by clearing bit DMAMC.DEn = 0.                                                                                                                                                                  |

If the DMAMC.DEn bit is cleared during a DMA transfer action, the current transfer action is finished before the DMA transfer is stopped (see *"Example of forcible termination of DMA transfer" on page 240*).



# 10.1.3 DMA interrupt function

The DMA triggers are interrupt signals of

- A/D Converters
- serial interfaces
- Timer S

These interrupts (except Timer S) are shared with their corresponding DMA transfer completion interrupts (INTDMAn). If a DMA channel is enabled, the peripheral I/O interrupt corresponding to the DMA trigger can no longer generate an interrupt request. Instead, the DMA transfer completion interrupt can generate an interrupt with the corresponding interrupt handler address.

The DMA triggers of Timers S (INTTSnOD and INTTSnCD0) are *not* shared with their DMA transfer completion interrupts (INTDMAn). These DMA completion interrupts have dedicated entries in the interrupt source list (refer to *"Interrupt Controller (INTC)" on page 99*).

*Table 10-1* shows the relations between DMA triggers and DMA completion interrupts.

# Table 10-1 Relations between DMA triggers and DMA completion interrupts DMA completion interrupt

|             |                          | DMA completion interrupt |                                         |                        |  |  |  |
|-------------|--------------------------|--------------------------|-----------------------------------------|------------------------|--|--|--|
| DMA channel | DMA trigger              | Name                     | Entry in<br>interrupt list <sup>a</sup> | Handler<br>address     |  |  |  |
| 0           | ADDMARQ0                 | INTDMA0                  | INTAD0                                  | 0000 0790 <sub>H</sub> |  |  |  |
| 1           | ADDMARQ1                 | INTDMA1                  | INTAD1                                  | 0000 07A0 <sub>H</sub> |  |  |  |
| 2           | INTTS0CD0 or<br>INTTS0OD | INTDMA2                  | INTDMA2                                 | 0000 07B0 <sub>H</sub> |  |  |  |
| 3           | INTTS1CD0 or<br>INTTS1OD | INTDMA3                  | INTDMA3                                 | 0000 07C0 <sub>H</sub> |  |  |  |
|             | INTCE0C                  | INTDMA4,                 | INTCE0C                                 | 0000 0720 <sub>H</sub> |  |  |  |
|             | INTCE1C                  | INTDMA5                  | INTCE1C                                 | 0000 0740 <sub>H</sub> |  |  |  |
|             | INTCB0R                  |                          | INTCB0R                                 | 0000 06C0 <sub>H</sub> |  |  |  |
| 4, 5        | INTCB1R                  |                          | INTCB1R                                 | 0000 06F0 <sub>H</sub> |  |  |  |
|             | INTUC0R                  |                          | INTUC0R                                 | 0000 00E0 <sub>H</sub> |  |  |  |
|             | INTUC1R                  |                          | INTUC1R                                 | 0000 00F0 <sub>H</sub> |  |  |  |
|             | INTCE0C                  | INTDMA6,                 | INTCE0C                                 | 0000 0720 <sub>H</sub> |  |  |  |
|             | INTCE1C                  | INTDMA7                  | INTCE1C                                 | 0000 0740 <sub>H</sub> |  |  |  |
|             | INTCB0T                  |                          | INTCB0T                                 | 0000 06B0 <sub>H</sub> |  |  |  |
| 6, 7        | INTCB1T                  |                          | INTCIB1T                                | 0000 06E0 <sub>H</sub> |  |  |  |
|             | INTUC0T                  |                          | INTUC0T                                 | 0000 0760 <sub>H</sub> |  |  |  |
|             | INTUC1T                  |                          | INTUC1T                                 | 0000 0780 <sub>H</sub> |  |  |  |

a) The interrupt/exception list is given in "Interrupt Controller (INTC)" on page 99



# 10.2 Registers

The DMA Controller is controlled by means of the following registers:

# Table 10-2 DMA Controller register overview

| Register name                               | Shortcut              | Address                                        |
|---------------------------------------------|-----------------------|------------------------------------------------|
| DMA wait control registers                  | DMAWC0                | FFFF FE00 <sub>H</sub>                         |
|                                             | DMAWC1                | FFFF FE02 <sub>H</sub>                         |
| DMA transfer SFR start address registers    | SAR2                  | <base/> + 24 <sub>H</sub>                      |
|                                             | SAR3                  | <base/> + 26 <sub>H</sub>                      |
| DMA transfer memory start address registers | MARn<br>(n = 0 to 7)  | <base/> + n x 2 <sub>H</sub>                   |
| DMA trigger factor registers                | DTFR4                 | <base/> + 88 <sub>H</sub>                      |
|                                             | DTFR5                 | <base/> + 8A <sub>H</sub>                      |
|                                             | DTFR6                 | <base/> + 8C <sub>H</sub>                      |
|                                             | DTFR7                 | <base/> + 8E <sub>H</sub>                      |
| DMA transfer count registers                | DTCRn<br>(n = 0 to 7) | <base/> + 40 <sub>H</sub> + n x 2 <sub>H</sub> |
| DMA status register                         | DMASL                 | <base/> + 62 <sub>H</sub>                      |
| DMA mode control register                   | DMAMCL                | <base/> + 60 <sub>H</sub>                      |
| DMA data size control register              | DMADSCL               | <base/> + 64 <sub>H</sub>                      |

# Table 10-3 DMA Controller register base address

| Unit           | Base address           |
|----------------|------------------------|
| DMA Controller | FFFF F300 <sub>H</sub> |



| (1)           | DMAWCm - DMA wait control registers                                                                                                               |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
|               | The 8-bit DMAWCm registers control the internal bus timing for DMA transfers $(m = 0, 1)$ .                                                       |
| Access        | These registers can be read/written in 8-bit units.                                                                                               |
| Address       | DMAWC0: FFFF FE00 <sub>H</sub><br>DMAWC1: FFFF FE02 <sub>H</sub>                                                                                  |
| Initial Value | DMAWC0: 37 <sub>H</sub><br>DMAWC1: 07 <sub>H</sub>                                                                                                |
| DMAWC0        | The DMAWC0 register must have the same setting as the internal peripheral function wait control register VSWC:                                    |
|               | DMAWC0 = VSWC.                                                                                                                                    |
|               | Note that the contents of the VSWC register depend on the system clock (see <i>"Bus and Memory Control (BCU, MEMC)" on page 192</i> for details). |
| DMAWC1        | The DMAWC1 register must be set as follows:<br>DMAWC1 = $00_{H}$ .                                                                                |

**Caution** The DMAWCm registers must be set up correctly before the first DMA transfer is started. Do not change these registers afterwards.



#### (2) SARn - DMA transfer SFR start address registers

The 8-bit SARn register specifies the start address of the TMS register for which the DMA transfer is started on the corresponding DMA channel n (n = 2, 3).

This register is only valid for DMA transfers to timers S.

Access This register can be read/written in 8-bit or 1-bit units.

Address SAR2: <base> + 24<sub>H</sub> SAR3: <base> + 26<sub>H</sub>

Initial Value 0x00.

| 7 | 6 | 5 | 4 | 3     | 2     | 1     | 0     |
|---|---|---|---|-------|-------|-------|-------|
| 0 | 0 | 0 | 0 | SARn3 | SARn2 | SARn1 | SARn0 |
| R | R | R | R | R/W   | R/W   | R/W   | R/W   |

Writing to SARn.bit[7:4] is ignored.

| Table 10-4 | SARn register contents |
|------------|------------------------|
|            |                        |

| Bit<br>position | Bit name                | Function                                                                                                                        |       |       |       |                                                   |                        |                                   |                         |
|-----------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------|-------|-------|-------|---------------------------------------------------|------------------------|-----------------------------------|-------------------------|
|                 |                         | Sets the start address of the TMS register for which the DMA transfer is started on the corresponding DMA channel n (n = 2, 3). |       |       |       |                                                   |                        |                                   |                         |
|                 |                         | SARn3                                                                                                                           | SARn2 | SARn1 | SARn0 | DMA transfer start address of TMS reload register |                        |                                   |                         |
|                 |                         |                                                                                                                                 |       |       |       | n = 2                                             |                        | n = 3                             |                         |
|                 |                         |                                                                                                                                 |       |       |       | Register                                          | Address                | Register                          | Address                 |
|                 |                         | 0                                                                                                                               | 0     | 0     | 0     | TS0OPT1A                                          | FFFF FB40 <sub>H</sub> | TS10PT1A                          | FFFF FBC0 <sub>H</sub>  |
|                 |                         | 0                                                                                                                               | 0     | 0     | 1     | TS0DTC1A                                          | FFFF FB42 <sub>H</sub> | TS1DTC1A                          | FFFF FBC2 <sub>H</sub>  |
| 3 to 0          | SARn[3:0]<br>(n = 2, 3) | 0                                                                                                                               | 0     | 1     | 0     | TSODTCOA                                          | FFFF FB44 <sub>H</sub> | TS1DTC0A                          | FFFF FBC4 <sub>H</sub>  |
|                 |                         | 0                                                                                                                               | 0     | 1     | 1     | TS0CCR5A                                          | FFFF FB46 <sub>H</sub> | TS1CCR5A                          | 0FFFF FBC6 <sub>H</sub> |
|                 |                         | 0                                                                                                                               | 1     | 0     | 0     | TS0CCR4A                                          | FFFF FB48 <sub>H</sub> | TS1CCR4A                          | FFFF FBC8 <sub>H</sub>  |
|                 |                         | 0                                                                                                                               | 1     | 0     | 1     | TS0CCR3B                                          | FFFF FB4A <sub>H</sub> | TS1CCR3B                          | FFFF FBCA <sub>H</sub>  |
|                 |                         | 0                                                                                                                               | 1     | 1     | 0     | TS0CCR2B/<br>TS0PAT1 <sup>a</sup>                 | FFFF FB4C <sub>H</sub> | TS1CCR2B/<br>TS1PAT1 <sup>b</sup> | FFFF FBCC <sub>H</sub>  |
|                 |                         | 0                                                                                                                               | 1     | 1     | 1     | TS0CCR1B/<br>TS0PAT0 <sup>c</sup>                 | FFFF FB4E <sub>H</sub> | TS1CCR1B/<br>TS1PAT0 <sup>d</sup> | FFFF FBCE <sub>H</sub>  |
|                 |                         | 1                                                                                                                               | 0     | 0     | 0     | TSOCCROA                                          | FFFF FB50 <sub>H</sub> | TS1CCR0A                          | FFFF FBD0 <sub>H</sub>  |
|                 |                         | 1                                                                                                                               | 0     | 0     | 1     | TS0CCR3A                                          | FFFF FB52 <sub>H</sub> | TS1CCR3A                          | FFFF FBD2 <sub>H</sub>  |
|                 |                         | 1                                                                                                                               | 0     | 1     | 0     | TS0CCR2A                                          | FFFF FB54 <sub>H</sub> | TS1CCR2A                          | FFFF FBD4 <sub>H</sub>  |
|                 |                         | 1                                                                                                                               | 0     | 1     | 1     | TS0CCR1A                                          | FFFF FB56 <sub>H</sub> | TS1CCR1A                          | FFFF FBD6 <sub>H</sub>  |
|                 |                         | other settings than above                                                                                                       |       |       |       | prohibited                                        |                        |                                   |                         |

a) TS0CCR2B in T-PWM mode, TSOPAT1 in all other modes

b) TS1CCR2B in T-PWM mode, TS1PAT1 in all other modes

c) TS0CCR1B in T-PWM mode, TS0PAT0 in all other modes

d) TS1CCR1B in T-PWM mode, TS1PAT0 in all other modes



## (3) MARn - DMA transfer memory start address registers

The 16-bit MARn register specifies the subordinated 16 bits of

- the source address (transfer direction iRAM  $\rightarrow$  I/O)
- the destination start address (transfer direction I/O  $\rightarrow$  iRAM)

within the internal RAM area for the DMA channel n.

Access This register can be read/written in 16-bit units.

Address <base> + n x 2<sub>H</sub>

Initial Value 0x0000.

| 15     | 14     | 13     | 12     | 11     | 10     | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|--------|--------|--------|--------|--------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| MARn15 | MARn14 | MARn13 | MARn12 | MARn11 | MARn10 | MARn9 | MARn8 | MARn7 | MARn6 | MARn5 | MARn4 | MARn3 | MARn2 | MARn1 | MARn0 |
| R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |

#### Table 10-5 MARn register contents

| Bit position | Bit name | Function                                                                     |
|--------------|----------|------------------------------------------------------------------------------|
| 15 to 0      |          | Sets the subordinated 16 bits of the DMA transfer start address (A15 to A0). |

Caution

- 1. Due to the internal RAM size, the value written to the MARn register has to be in the range from  $FFF_7000_H$  to  $FFF_EFFF_H$ .
- 2. For DMA channels that are configured for 16-bit transfer data units, the RAM source or destination area must be 16 bit aligned. Thus the memory address must be even, that is MARn.MARn0 = 0.



#### (4) DTFRn - DMA trigger factor registers

The 8-bit DTFRn register controls the DMA transfer start trigger of DMA channel n via interrupt requests from on-chip peripheral I/O (n = 4 to 7).

The interrupt request set by this register serves as DMA transfer start factor.

This register is only valid for DMA transfers to serial interfaces.

Access This register can be read/written in 8-bit units.

Address DTFR4: <base> + 88<sub>H</sub> DTFR5: <base> + 8A<sub>H</sub> DTFR6: <base> + 8C<sub>H</sub> DTFR7: <base> + 8E<sub>H</sub>

**Initial Value**  $00_{\text{H}}$ . This register is cleared by RESET.

| 7   | 6   | 5   | 4   | 3   | 2     | 1     | 0     |
|-----|-----|-----|-----|-----|-------|-------|-------|
| 0   | 0   | 0   | 0   | 0   | IFCn2 | IFCn1 | IFCn0 |
| R/W | R/W | R/W | R/W | R/W | R/W   | R/W   | R/W   |

Caution 1. Do not set the same DMA trigger by different DTFRn registers.

- Do not rewrite the DTFRn register until a started DMA transfer ends (corresponding DTCRn register value is 00<sub>H</sub>).
- **3.** Write the DTFRn register before setting the corresponding DTCRn register. Otherwise, if the DMA trigger is present, the DMA transfer might be started by writing the DTFRn register.

| Table 10-6 | DTFRn register | contents |
|------------|----------------|----------|
|------------|----------------|----------|

| Bit position | Bit name                  |                                | Function           |       |                                                    |                    |  |  |  |
|--------------|---------------------------|--------------------------------|--------------------|-------|----------------------------------------------------|--------------------|--|--|--|
|              |                           | Sets the DMA<br>on-chip periph | rupt requests from |       |                                                    |                    |  |  |  |
|              |                           | IFCn2                          | IFCn1              | IFCn0 | DMA transfe                                        | er start factor    |  |  |  |
|              |                           | 11 0112                        |                    |       | when n = 4, 5                                      | when n = 6, 7      |  |  |  |
|              |                           | 0                              | 0                  | 0     | DMA request from on-chip periphera<br>I/O disabled |                    |  |  |  |
| 0.4- 0       | IFCn[2:0]<br>(n = 4 to 7) | 0                              | 0                  | 1     | INTUC0R                                            | INTUC0T            |  |  |  |
| 2 to 0       |                           | 0                              | 1                  | 0     | INTUC1R                                            | INTUC1T            |  |  |  |
|              |                           | 0                              | 1                  | 1     | INTCB0R                                            | INTCB0T            |  |  |  |
|              |                           | 1                              | 0                  | 0     | INTCB1R                                            | INTCB1T            |  |  |  |
|              |                           | 1                              | 0                  | 1     | INTCE0C                                            | INTCE0C            |  |  |  |
|              |                           | 1                              | 1                  | 0     | INTCE1C                                            | INTCE1C            |  |  |  |
|              |                           | 1                              | 1                  | 1     | setting prohibited                                 | setting prohibited |  |  |  |
|              |                           |                                | •                  | •     |                                                    | ·                  |  |  |  |



#### (5) DTCRn - DMA transfer count registers

The 8-bit DTCRn register has two functions:

- Before DMA transfer, it sets the transfer count for DMA channel n.
- During DMA transfer, it stores the remaining transfer count.

Access This register can be read/written in 8-bit units.

Address <br/> <br/>base> +  $40_{H}$  + n x  $2_{H}$ 

Initial Value 0x00.

| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|--------|--------|--------|--------|--------|--------|--------|--------|
| DTCRn7 | DTCRn6 | DTCRn5 | DTCRn4 | DTCRn3 | DTCRn2 | DTCRn1 | DTCRn0 |
| R/W    |

| Bit position | Bit name   | Function                    |        |       |           |              |             |                               |   |
|--------------|------------|-----------------------------|--------|-------|-----------|--------------|-------------|-------------------------------|---|
|              |            | Sets the tran<br>during DMA |        | for D | MA channe | I n and stor | es the rema | aining transfer count         |   |
|              |            | DTCRn7                      | DTCRn6 |       | DTCRn2    | DTCRn1       | DTCRn0      | Remaining DMA transfer counts |   |
|              |            | 0                           | 0      |       | 0         | 0            | 0           | 256                           |   |
|              | DTCRn[7:0] | 0                           | 0      |       | 0         | 0            | 1           | 1                             |   |
| 7 to 0       |            | DTCRn[7:0]                  | 0      | 0     |           | 0            | 1           | 0                             | 2 |
|              |            | 0                           | 0      |       | 0         | 1            | 1           | 3                             |   |
|              |            |                             |        |       |           |              |             |                               |   |
|              |            | 1                           | 1      |       | 1         | 0            | 1           | 253                           |   |
|              |            | 1                           | 1      |       | 1         | 1            | 0           | 254                           |   |
|              |            | 1                           | 1      |       | 1         | 1            | 1           | 255                           |   |
|              |            |                             | 1      | I     | 1         | I            | 1           | I                             |   |

- Caution 1. The value set to the DTCRn register is decreased by each DMA transfer of channel n. It does not keep the initial value after the DMA transfer ends. Therefore, after DMA transfer end the DTCRn register value becomes 00<sub>H</sub>.
  - A DMA request becomes only effective after the DTCRn register was written. Even if 00<sub>H</sub> (means a transfer count of 256) is the initial value, the DTRCn register must be rewritten in order to enable a new DMA transfer.
  - Writing to the DTCRn register during DMA transmission (DMAMC.DEn=1) is prohibited.
  - 4. The DMA transfer ends if DTCRn becomes 00<sub>H</sub>. Thus even if a new DMA trigger occurs no transfer takes place and no DMA interrupt is generated.



#### (6) DMASL - DMA status register

The 8-bit DMASL register displays the transfer status of the DMA channels.

Access This register can be read/written in 8-bit and 1-bit units.

Address <base> + 62<sub>H</sub>

Initial Value 00<sub>H</sub>. This register is cleared by RESET.

| 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|-------|-------|-------|-------|-------|-------|-------|
| DMAS7 | DMAS6 | DMAS5 | DMAS4 | DMAS3 | DMAS2 | DMAS1 | DMAS0 |
| R/W   |

#### Table 10-8 DMASL register contents

| Bit position | Bit name | Function                                                                                                         |
|--------------|----------|------------------------------------------------------------------------------------------------------------------|
| 7 to 0       | DMASn    | Displays the transfer status of DMA channel n:<br>0: Transfer is idle or on progress<br>1: Transfer is completed |

- Note 1. The DMASn bit can be read and written, but it can only be cleared by writing 0 to it, and it cannot be set by writing 1 to it.
  - 2. Since the DMASn bit is not cleared by the DMAC, it has to be cleared by software before DMA transfer is started.



# (7) DMAMCL - DMA mode control register

The 8-bit DMAMCL register enables/disables the operation of the DMA channels.

- Access This register can be read/written in 8-bit and 1-bit units.
- Address <base> + 60<sub>H</sub>

Initial Value 00<sub>H</sub>. This register is cleared by RESET.

| 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|
| DE7 | DE6 | DE5 | DE4 | DE3 | DE2 | DE1 | DE0 |
| R/W |

#### Table 10-9 DMAMCL register contents

| Bit position | Bit name | Function                                                                                     |
|--------------|----------|----------------------------------------------------------------------------------------------|
| 7 to 0       | DEn      | Enables/disables DMA transfer of channel n:<br>0: Operation disabled<br>1: Operation enabled |

**Caution** Writing of a DEn bit is prohibited if the corresponding peripheral function, that generates the DMA trigger, is operating.



#### (8) DMADSCL - DMA data size control register

The 8-bit DMADSCL register controls the transfer data size of DMA channels 4 to 7. The transfer data size of DMA channels 0 to 3 is fixed to 16 bits.

This register is only valid for DMA transfers to serial interfaces.

Access This register can be read/written in 8-bit and 1-bit units.

Address <base> + 64<sub>H</sub>

Initial Value  $00_{H}$ . This register is cleared by RESET.

| 7       | 6       | 5       | 4       | 3   | 2   | 1   | 0   |
|---------|---------|---------|---------|-----|-----|-----|-----|
| DMADSC7 | DMADSC6 | DMADSC5 | DMADSC4 | 0   | 0   | 0   | 0   |
| R/W     | R/W     | R/W     | R/W     | R/W | R/W | R/W | R/W |

#### Table 10-10 DMADSCL register contents

| Bit position | Bit name                | Function                                                                 |
|--------------|-------------------------|--------------------------------------------------------------------------|
| 7 to 4       | DMADSCn<br>(n = 4 to 7) | Sets the transfer data size of DMA channel n:<br>0: 8 bits<br>1: 16 bits |



# 10.3 Transfer Details

This section presents details and examples of all possible DMA transfers:

- "DMA transfer from A/D Converter" on page 223
- "DMA transfer to Timer S" on page 227
- \* "DMA transfer to/from serial interfaces" on page 232

Further, an *"Example of forcible termination of DMA transfer" on page 240* is given.

# 10.3.1 DMA transfer from A/D Converter

**Caution** For transferring A/D Converter results from the A/D Converter to the internal RAM via DMA the A/D Converter has to be operated in timer triggered scan mode. Refer to *"A/D Converter (ADC)" on page 506* for information how to set up this mode.

The following table summarizes the DMA transfer ADCm  $\rightarrow$  iRAM (m = 0, 1).

| Table 10-11 | Overview of DMA transfer from A/D Converter |
|-------------|---------------------------------------------|
|-------------|---------------------------------------------|

|              |                  |          |                                |               |                    | Transfe                              | r                   |
|--------------|------------------|----------|--------------------------------|---------------|--------------------|--------------------------------------|---------------------|
| Channel<br>n | Transfer<br>unit | DI       | Size                           | Max.<br>count | Source<br>register | Destination start<br>address<br>MARn |                     |
| 0            | ADC0             | ADDMARQ0 | End of<br>conversion interrupt | 16 bit        | 256                | ADDMA0<br>(fixed)                    | any even<br>address |
| 1            | ADC1             | ADDMARQ1 | signal of A/D<br>Converter     | TO DI         | 230                | ADDMA1<br>(fixed)                    | in iRAM             |

For each DMA trigger, the data will be transferred from the A/D conversion result register for DMA (ADDMAm) to the internal RAM area specified by the destination start address in MARn.

Transferred data The data that is to be transferred is defined by the following:

• A/D Converter scan area

The number of ADC channels that are to be scanned can be defined in the A/D Converter.

The DMA transfer is performed for every finished A/D conversion within the A/D Converter scan area. Thus, for every ADC channel, a separate DMA transfer is required.

- DMA transfer count The number of DMA transfers has to be defined in the DTCRn register. The total number of DMA transfers can be calculated as scan area size × number of DMA triggers
- **Note** The user has to take care that the number of DMA transfer counts complies with the A/D Converter scan area size and the number of A/D Converter start triggers.

For an example see "Example of DMA transfer of A/D Converter results" on page 226.



## (1) Principle of DMA transfer of A/D conversion results



Figure 10-1 Initialization of DMA Channel 0/1 for Transfer of A/D Conversion Results





Figure 10-2 Operation of DMA Channel 0/1

**Note** The DMA completion interrupt has the same interrupt vector address as the A/D conversion completion interrupt (INTADm) of the corresponding ADCm, and replaces that interrupt.



| -            |                                                                                                                                                                                                 |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (2)          | Example of DMA transfer of A/D Converter results                                                                                                                                                |
|              | <i>Figure 10-3</i> exemplifies a DMA transfer from the A/D conversion result register of ADC0 to the internal RAM.                                                                              |
| Example      | The following steps are performed by the exemplary application program.                                                                                                                         |
|              | <1> Setup of DMA transfer:<br>MARn = 1000 <sub>H</sub> ( <i>start address of FFFF1000<sub>H</sub> in iRAM</i> )<br>DTCRn = 04 <sub>H</sub> ( <i>DMA ransfer count is 4</i> )<br>DMASL.DMASn = 0 |
|              | <2> Start DMA transfer:<br>DMAMCL.DEn = 1                                                                                                                                                       |
|              | <3> Enable ADCm:<br>ADMm0.ADCEm = 1                                                                                                                                                             |
|              | <4> Disable ADCm:<br>ADMm0.ADCEm = 0                                                                                                                                                            |
|              | <5> Re-setup and restart of the DMA transfer:<br>DTCRn = 04 <sub>H</sub><br>DMASL.DMASn = 0                                                                                                     |
|              | <6> Restart of the DMA transfer:<br>DMAMCL.DEn = 1                                                                                                                                              |
|              | <7> Enable ADCm:<br>ADMm0.ADCEm = 1                                                                                                                                                             |
| -1101        |                                                                                                                                                                                                 |
| <1> <2> <    | 3> <4><5><6><7><br>ПППППППППППП                                                                                                                                                                 |
|              |                                                                                                                                                                                                 |
| DMA Transfer |                                                                                                                                                                                                 |
| DEn Bit      |                                                                                                                                                                                                 |
| MARn         | 1000н X 1002н X 1006н X 1008н X 100Ан X 100Сн X 100Ен X 1010н                                                                                                                                   |
| DTCRn        | 04н Х 03н Х 02н Х 01н Х 00н Х 04н Х 03н Х 02н Х 01н Х 00н                                                                                                                                       |
| DMASn Bit    |                                                                                                                                                                                                 |

Figure 10-3 Exemplary Timing Diagram of a DMA Transfer of A/D Conversion Result

h

INTADm



# 10.3.2 DMA transfer to Timer S

The following table summarizes the DMA transfer iRAM  $\rightarrow$  TMSm (m = 0, 1):

|         |          |                        |                    |        | Transfer              |                     |                     |           |  |  |
|---------|----------|------------------------|--------------------|--------|-----------------------|---------------------|---------------------|-----------|--|--|
| Channel | Transfer | DMA tri                | aaer               |        | Max.                  | Source address      | Destination address |           |  |  |
| n       | unit     |                        | 33                 | Size   | count                 | (MARn)              | Start<br>(SARn)     | End       |  |  |
| 2       | TMS0     | INTTS0OD,<br>INTTS0CD0 | TSmCNT<br>top /    | 16 bit | 01 <sub>H</sub><br>to | any<br>even address | refer<br>to         | TSmCCR1A  |  |  |
| 3       | TMS1     | INTTS1OD,<br>INTTS1CD0 | bottom<br>reversal | 10 Dit | 03 <sub>H</sub>       | in iRAM             | below<br>table      | Tomoortik |  |  |

For each DMA trigger, the data will be transferred from internal RAM to the capture/compare registers of timer TMSm.

**Transferred data** The data that is to be transferred is defined by the following destination area:

• The destination start address

It is defined by the SARn.SARn[3:0] register bits. The address offset of the Timer S DMA start register is evaluated from SARn.SARn[3:0] (refer to below table).

- The *destination end address* It is fixed to the TSmCCR1A register of Timer TMSm.
- The timer TMS address mapping

It defines the order in which registers are written to. The table below lists all possible destination registers together with their address offset and related setting of SARn.SRAn[3:0]:

| DMA transfer destination address |                 |                 |                                |  |  |  |  |
|----------------------------------|-----------------|-----------------|--------------------------------|--|--|--|--|
| TMSm registers                   | SARn.SARn[3:0]  | Address Offset  |                                |  |  |  |  |
| TSmOPT1A                         | 00 <sub>H</sub> | 00 <sub>H</sub> | Selectable as                  |  |  |  |  |
| TSmDTC1                          | 01 <sub>H</sub> | 02 <sub>H</sub> | destination start<br>address   |  |  |  |  |
| TSmDTC0                          | 02 <sub>H</sub> | 04 <sub>H</sub> |                                |  |  |  |  |
| TSmCCR5A                         | 03 <sub>H</sub> | 06 <sub>H</sub> |                                |  |  |  |  |
| TSmCCR4A                         | 04 <sub>H</sub> | 08 <sub>H</sub> |                                |  |  |  |  |
| TSmCCR3B                         | 05 <sub>H</sub> | 0A <sub>H</sub> |                                |  |  |  |  |
| TSmCCR2B/<br>TSmPAT1             | 06 <sub>H</sub> | 0C <sub>H</sub> |                                |  |  |  |  |
| TSmCCR1B/<br>TSmPAT0             | 07 <sub>H</sub> | 0E <sub>H</sub> |                                |  |  |  |  |
| TSmCCR0A                         | 08 <sub>H</sub> | 10 <sub>H</sub> |                                |  |  |  |  |
| TSmCCR3A                         | 09 <sub>H</sub> | 12 <sub>H</sub> |                                |  |  |  |  |
| TSmCCR2A                         | 0A <sub>H</sub> | 14 <sub>H</sub> |                                |  |  |  |  |
| TSmCCR1A                         | 0B <sub>H</sub> | 16 <sub>H</sub> | Always destination end address |  |  |  |  |



The DMA transfer is performed for every reload of the internal buffer compare registers by the contents of the capture/compare registers TSmCCR0A to TSmCCR5A.

With every DMA transfer, data is written to all registers within the destination area.

For an example see "Example of DMA transfer for timer S reload" on page 231.



#### (1) Principle of DMA transfer for timer S reload



Figure 10-4 Initialization of DMA Channel 2/3 for Timer S Reload





Figure 10-5 Operation of DMA Channel 2/3



(2) Example of DMA transfer for timer S reload

*Figure 10-3* exemplifies a DMA transfer from the internal RAM to timer TMS0 compare registers for reload.

- **Example** The following steps are performed by the exemplary application program.
  - <1> Setup of DMA transfer: SAR2 =  $08_H$  (means start register is TSmCCR0A) MAR2 =  $C000_H$  (means start address of FFFFC000<sub>H</sub> in iRAM) DTCR2 =  $02_H$  (means a transfer count of 2) DMASL.DMAS2 = 0
  - <2> Ensure that DMA trigger factor (INTTS0OD or INTTS0CD0) does not occur when DE2 is set, otherwise disable TMS0: TS0CTL0.TS0CEm = 0
  - <3> Start DMA transfer: DMAMCL.DE2 = 1
  - <4> If disabled, enable TMS0: TS0CTL0.TS0CE= 1



Figure 10-6 Exemplary Timing Diagram of DMA Transfer for TMS0 Reload



# 10.3.3 DMA transfer to/from serial interfaces

#### (1) Serial data reception with DMA transfer

The DMA channels 4 and 5 are dedicated to transfer data from serial interfaces CSIE0, CSIE1, CSIB0, CSIB1, UARTC0, UARTC1to the iRAM.

The following table summarizes the DMA transfer serial interface  $\rightarrow$  iRAM:

 Table 10-13
 Overview of DMA transfer from serial interfaces

|              |                  | DMA trigger |                       |        | Transfer      |                    |                                        |  |  |  |
|--------------|------------------|-------------|-----------------------|--------|---------------|--------------------|----------------------------------------|--|--|--|
| Channel<br>n | Transfer<br>unit |             |                       | Size   | Max.<br>count | Source address     | Destination<br>start address<br>(MARn) |  |  |  |
|              | CSIE0            | INTCE0C     | Receive               | 8 bit  | 255           | CEORXOL            | Any iRAM address                       |  |  |  |
|              |                  |             | complete<br>interrupt | 16 bit |               | CE0RX0             | Any even iRAM address                  |  |  |  |
|              | CSIE1            | INTCE1C     |                       | 8 bit  |               | CE1RX0L            | Any iRAM address                       |  |  |  |
|              |                  |             |                       | 16 bit |               | CE1RX0             | Any even iRAM address                  |  |  |  |
|              | UARTC0           | INTUC0R     |                       | 8 bit  |               | UCORX              | Any iRAM address                       |  |  |  |
|              |                  |             |                       | 16 bit |               | Setting prohibited |                                        |  |  |  |
| 4            | UARTC1           | INTUC1R     |                       | 8 bit  |               | UC1RX              | Any iRAM address                       |  |  |  |
| 4            |                  |             |                       | 16 bit |               | Setting prohibited |                                        |  |  |  |
|              | CSIB0            | INTCB0R     |                       | 8 bit  |               | CB0RXL             | Any iRAM address                       |  |  |  |
|              |                  |             |                       | 16 bit |               | CB0RX              | Any even iRAM address                  |  |  |  |
|              | CSIB1            | INTCB1R     |                       | 8 bit  |               | CB1RXL             | Any iRAM address                       |  |  |  |
|              |                  |             |                       | 16 bit |               | CB1RX              | Any even iRAM address                  |  |  |  |
|              | CSIE0            | INTCE0C     |                       | 8 bit  |               | CE0RX0L            | Any iRAM address                       |  |  |  |
|              |                  |             |                       | 16 bit |               | CE0RX0             | Any even iRAM address                  |  |  |  |
|              | CSIE1            | INTCE1C     |                       | 8 bit  |               | CE1RX0L            | Any iRAM address                       |  |  |  |
|              |                  |             |                       | 16 bit |               | CE1RX0             | Any even iRAM address                  |  |  |  |
|              | UARTC0           | INTUC0R     |                       | 8 bit  |               | UCORX              | Any iRAM address                       |  |  |  |
|              |                  |             |                       | 16 bit |               | Setting prohibited |                                        |  |  |  |
| 5            | UARTC1           | INTUC1R     |                       | 8 bit  |               | UC1RX              | Any iRAM address                       |  |  |  |
| 5            |                  |             |                       | 16 bit |               | Setting prohibited |                                        |  |  |  |
|              | CSIB0            | INTCB0R     |                       | 8 bit  |               | CB0RXL             | Any iRAM address                       |  |  |  |
|              |                  |             |                       | 16 bit |               | CB0RX              | Any even iRAM address                  |  |  |  |
|              | CSIB1            | INTCB1R     |                       | 8 bit  |               | CB1RXL             | Any iRAM address                       |  |  |  |
|              |                  |             |                       | 16 bit |               | CB1RX              | Any even iRAM address                  |  |  |  |



| Chapter 10          | DMA Functions (DMA Controller)                                                                                                                                                                                                                                                                                                                          |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Source address      | The source address is any of the listed serial interfacesof ' data receive registers. It is implicitly defined by the channel number n and the selection made by the DMA trigger factor register DTFRn register.                                                                                                                                        |
| Destination address | The destination address is any iRAM address (for 16-bit transfers an even iRAM address), specified by the DMA memory start address MARn.                                                                                                                                                                                                                |
| DMA trigger         | Upon each DMA trigger 8-bit or 16-bit data is transferred from the corresponding serial reception register to the internal RAM.                                                                                                                                                                                                                         |
|                     | The DMA trigger is the end-of-reception interrupt signal of the selected serial interface. Like the source address, It is defined by the DMA channel number and the DMA trigger factor register DTFRn register.                                                                                                                                         |
| Transfer size       | <ul> <li>The transfer data size can be set to 8- or 16-bit via the register DMADSCL.</li> <li>In case of 8-bit transfer data size, the destination address is incremented by 1 for each DMA trigger.</li> <li>In case of 16-bit transfer data size, the destination address MARn must be even, and is incremented by 2 for each DMA trigger.</li> </ul> |







Figure 10-7 Initialization of DMA Channel 4/5 for Serial Data Reception





Figure 10-8 Operation of DMA Channel 4/5

**Note** The interrupt vector address of the DMA transfer completion interrupt overlays and replaces the corresponding reception completion interrupt of the serial interface source specified by the DTFRn register.



#### (3) Serial data transmission with DMA transfer

The DMA channels 6 and 7 are dedicated to transfer data from the iRAM to the serial interfaces CSIE0, CSIE1, CSIB0, CSIB1, UARTC0, UARTC1.

The following table summarizes the DMA transfer iRAM  $\rightarrow$  serial interface:

| Channel | Transfer           | DMA trigger |           | Transfer |               |                          |                           |  |  |
|---------|--------------------|-------------|-----------|----------|---------------|--------------------------|---------------------------|--|--|
| n       | unit               |             |           | Size     | Max.<br>count | Source address<br>(MARn) | Destination start address |  |  |
|         | CSIE0 <sup>a</sup> | INTCE0C     | Transmit  | 8 bit    | 255           | Any iRAM address         | CE0TX0L                   |  |  |
|         |                    |             | interrupt | 16 bit   |               | Any even iRAM address    | CE0TX0                    |  |  |
|         | CSIE1 <sup>a</sup> | INTCE1C     |           | 8 bit    |               | Any iRAM address         | CE1TX0L                   |  |  |
|         |                    |             |           | 16 bit   |               | Any even iRAM address    | CE1TX0                    |  |  |
|         | UARTC0             | INTUC0T     |           | 8 bit    |               | Any iRAM address         | UC0TX                     |  |  |
|         |                    |             |           | 16 bit   |               | Setting prohibited       |                           |  |  |
| 6       | UARTC1             | INTUC1T     |           | 8 bit    |               | Any iRAM address         | UC1TX                     |  |  |
| 0       |                    |             |           | 16 bit   |               | Setting prohibited       |                           |  |  |
|         | CSIB0              | INTCB0T     |           | 8 bit    |               | Any iRAM address         | CB0TXL                    |  |  |
|         |                    |             |           | 16 bit   |               | Any even iRAM address    | CB0TX                     |  |  |
|         | CSIB1              | INTCB1T     |           | 8 bit    |               | Any iRAM address         | CB1TXL                    |  |  |
|         |                    |             |           | 16 bit   |               | Any even iRAM address    | CB1TX                     |  |  |
|         | CSIE0 <sup>a</sup> | INTCE0C     |           | 8 bit    |               | Any iRAM address         | CE0TX0L                   |  |  |
|         |                    |             |           | 16 bit   |               | Any even iRAM address    | CE0TX0                    |  |  |
|         | CSIE1 <sup>a</sup> | INTCE1C     |           | 8 bit    |               | Any iRAM address         | CE1TX0L                   |  |  |
|         |                    |             |           | 16 bit   |               | Any even iRAM address    | CE1TX0                    |  |  |
|         | UARTC0             | INTUC0T     |           | 8 bit    |               | Any iRAM address         | UC0TX                     |  |  |
|         |                    |             |           | 16 bit   |               | Setting prohibited       |                           |  |  |
| 7       | UARTC1             | INTUC1T     |           | 8 bit    |               | Any iRAM address         | UC1TX                     |  |  |
| /       |                    |             |           | 16 bit   |               | Setting prohibited       | •                         |  |  |
|         | CSIB0              | INTCB0T     |           | 8 bit    |               | Any iRAM address         | CB0TXL                    |  |  |
|         |                    |             |           | 16 bit   | 1             | Any even iRAM address    | CB0TX                     |  |  |
|         | CSIB1              | INTCB1T     | 1         | 8 bit    | 1             | Any iRAM address         | CB1TXL                    |  |  |
|         |                    |             |           | 16 bit   | 1             | Any even iRAM address    | CB1TX                     |  |  |

 Table 10-14
 Overview of DMA transfer to serial interfaces

<sup>a)</sup> Writing to the chip select data buffer registers CSnCS is not supported by DMA.



| Chapter 10          | DMA Functions (DMA Controller)                                                                                                                                                                                      |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Source address      | The source address is any iRAM address (for 16-bit transfers an even iRAM address), specified by the DMA memory start address MARn.                                                                                 |
| Destination address | The destination address is any of the listed serial interfaces' data transmit registers. It is implicitly defined by the channel number n and the selection made by the DMA trigger factor register DTFRn register. |
| DMA trigger         | Upon each DMA trigger 8-bit or 16-bit is transferred from the internal RAM to the corresponding serial transmit register.                                                                                           |
|                     | The DMA trigger is the transmit-enable interrupt signal of the selected serial interface. Like the destination address, It is defined by the DMA channel number and the DMA trigger factor register DTFRn register. |
| Transfer size       | <ul> <li>The transfer data size can be set to 8- or 16-bit via the register DMADSCL.</li> <li>In case of 8-bit transfer data size, the source address is incremented by 1 for each DMA trigger.</li> </ul>          |
|                     | <ul> <li>In case of 16-bit transfer data size, the source address MARn must be<br/>even, and is incremented by 2 for each DMA trigger.</li> </ul>                                                                   |



# (4) Principle of DMA transfer to serial interfaces (transmission)



Figure 10-9 Initialization of DMA Channel 6/7 for Serial Data Transmission





Figure 10-10 Operation of DMA Channel 6/7

**Note** The interrupt vector address of the DMA transfer completion interrupt overlays and replaces the corresponding transmission completion interrupt of the serial interface source specified by the DTFRn register.



# 10.3.4 Example of forcible termination of DMA transfer

- **CPU** 1. Set DMA transfer count (e.g. DTCRn =  $10_H$ )
  - 2. Start DMA transfer (DMAMCL.DEn = 1)
- DMA 3. Waiting for DMA trigger
  - 4. Start first data transfer
  - 5. Decrement DTCRn register by 1 (e.g. DTCRn =  $09_H$ )
  - 6. Waiting for DMA trigger
  - 7. Start next data transfer
- CPU 8. Stop DMA transfer forcibly (DMAMCL.DEn = 0)
- DMA 9. Decrement DTCRn register by 1 (e.g. DTCRn = 08<sub>H</sub>)
   10. DMA transfer is stopped completely



# Chapter 11 Asynchronous Serial Interface (UARTC)

This microcontroller has two instances of the universal Asynchronous Serial Interface UARTC.

Note Throughout this chapter, the individual instances of UARTCn are identified by "n" (n = 0 to 1), for example UCnCTL0 for the UARTCn control register 0.

# 11.1 Features

- Transfer rate: 300 bps to 4 Mbps
- Full-duplex communication:
  - Internal UARTC receive data register n (UCnRX)
  - Internal UARTC transmit data register n (UCnTX)
- 2-pin configuration:
  - TXDCn: Transmit data output pin
  - RXDCn: Receive data input pin
- Reception error output function
  - Parity error
  - Framing error
  - Overrun error
- Interrupt sources: 3
  - Reception complete interrupt (INTUCnR):

This interrupt occurs upon transfer of receive data from the shift register to receive buffer register n after serial transfer completion, in the reception enabled status.

- Transmission enable interrupt (INTUCnT):

This interrupt occurs upon transfer of transmit data from the transmit buffer register to the shift register in the transmission enabled status.

- Receive error interrupt (INTUCnRE):

This interrupt occurs upon transfer of erroneous receive data.

- Character length: 7, 8 bits
- Parity function: Odd, even, 0, none
- Transmission stop bit: 1, 2 bits
- On-chip dedicated baud rate generator
- MSB-/LSB-first transfer selectable
- Transmit/receive data level inversion possible



- 13 to 20 bits selectable for the SBF (Sync Break Field) in the LIN (Local Interconnect Network) communication format
  - Recognition of 11 bits or more possible for SBF reception in LIN communication format
  - SBF reception flag provided
- Extension bit operation possible (uses parity bit as 9th data bit)
- Transfer and reception status flags

# 11.2 Configuration

The block diagram of the UARTCn is shown below.





**Note** PCLK0 to PCLK9: peripheral clocks (refer to *"Clock Generator" on page 148*). For the configuration of the baud rate generator, see *Figure 11-11 on page 270*.

UARTCn consists of the following hardware units.

#### Table 11-1 Configuration of UARTCn



| Item      | Configuration                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Registers | UARTCn control register 0 (UCnCTL0)<br>UARTCn control register 1 (UCnCTL1)<br>UARTCn control register 2 (UCnCTL2)<br>UARTCn option control register 0 (UCnOPT0)<br>UARTCn option control register 1 (UCnOPT1)<br>UARTCn option control register 2 (UCnOPT2)<br>UARTCn status register (UCnSTR)<br>UARTCn receive shift register<br>UARTCn receive data register (UCnRX)<br>UARTCn transmit shift register |
|           | UARTCn transmit data register (UCnTX)                                                                                                                                                                                                                                                                                                                                                                     |

# (1) UARTCn control register 0 (UCnCTL0)

The UCnCTL0 register is an 8-bit register used to specify the UARTCn operation.

# (2) UARTCn control register 1 (UCnCTL1)

The UCnCTL1 register is an 8-bit register used to select the input clock for the UARTCn.

# (3) UARTCn control register 2 (UCnCTL2)

The UCnCTL2 register is an 8-bit register used to control the baud rate for the UARTCn.

# (4) UARTCn option control register 0 (UCnOPT0)

The UCnOPT0 register is an 8-bit register used to control serial transfer for the UARTCn.

# (5) UARTCn option control register 1 (UCnOPT1)

The UCnOPT1 register is an 8-bit register used to control the extension bit operation.

# (6) UARTCn option control register 2 (UCnOPT2)

The UCnOPT2 register is an 8-bit register indicates the operating status during a reception.

# (7) UARTCn status register (UCnSTR)

The UCnSTRn register consists of flags indicating the error contents when a reception error occurs. Each one of the reception error flags is set (to 1) upon occurrence of a reception error and is reset (to 0) by reading the UCnSTR register.

# (8) UARTCn receive shift register

This is a shift register used to convert the serial data input to the RXDCn pin into parallel data. Upon reception of 1 byte of data and detection of the stop bit, the receive data is transferred to the UCnRX register.

This register cannot be manipulated directly.



#### (9) UARTCn receive data register (UCnRX)

The UCnRX register is an 8-bit register that holds receive data. When 7 characters are received, 0 is stored in the highest bit (when data is received LSB first).

In the reception enabled status, receive data is transferred from the UARTCn receive shift register to the UCnRX register in synchronization with the completion of shift-in processing of 1 frame.

Transfer to the UCnRX register also causes the reception complete interrupt request signal (INTUCnR) to be output.

#### (10) UARTCn transmit shift register

The transmit shift register is a shift register used to convert the parallel data transferred from the UCnTX register into serial data.

When 1 byte of data is transferred from the UCnTX register, the shift register data is output from the TXDCn pin.

This register cannot be manipulated directly.

#### (11) UARTCn transmit data register (UCnTX)

The UCnTX register is an 8-bit transmit data buffer. Transmission starts when transmit data is written to the UCnTX register. When data can be written to the UCnTX register (when data of one frame is transferred from the UCnTX register to the UARTCn transmit shift register), the transmission enable interrupt request signal (INTUCnT) is generated.



# 11.3 UARTC Registers

#### (1) UCnCTL0 - UARTCn control register 0

The UCnCTL0 register is an 8-bit register that controls the UARTCn serial transfer operation.

Access This register can be read/written in 8-bit or 1-bit units.

Address UC0CTL0: FFFFFA00<sub>H</sub> UC1CTL0: FFFFFA20<sub>H</sub> UC2CTL0: FFFFFA40<sub>H</sub>

Initial Value 10<sub>H</sub>. This register is initialized by any reset.

|         | 7      | 6      | 5      | 4      | 3      | 2      | 1     | 0     |
|---------|--------|--------|--------|--------|--------|--------|-------|-------|
| UCnCTL0 | UCnPWR | UCnTXE | UCnRXE | UCnDIR | UCnPS1 | UCnPS0 | UCnCL | UCnSL |
|         | R/W    | R/W    | R/W    | R/W    | R/W    | R/W    | R/W   | R/W   |

Caution Be sure to set the UCnPWR bit = 1 and the UCnRXE bit = 1 while the RXDCn pin is high level (when UCnRDL bit of UCnOP0 register = 0). If the UCnPWR bit = 1 and the UCnRXE bit = 1 are set while the RXDCn pin is low level, reception will inadvertently start.

#### Table 11-2 UCnCTL0 register contents (1/2)

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7               | UCnPWR   | UARTCn Operation Control<br>0: Stops clock operation (UARTCn reset asynchronously)<br>1: LSB-first transfer<br>Operating clock control and UARTCn asynchronous reset are performed with the<br>UCnPWR bit. The TXDCn pin output is fixed to high level by setting the UCnPWR bit<br>to 0.                                                                                                                                                                                                                                                                                                                           |
| 6               | UCnTXE   | Transmission Operation Enable<br>0: Stops transmission operation<br>1: Enables transmission operation<br>The TXDCn pin output is fixed to high level by setting the UCnTXE bit to 0. Since the<br>UCnTXE bit is initialized by the operating clock, to initialize the transmission unit, set<br>UCnTXE from 0 to 1, and 2 clocks later, the transmission enabled status is entered.<br>Note: When UCnPWR bit = 0, the value written to the UCnTXE bit is ignored.                                                                                                                                                   |
| 5               | UCnRXE   | Reception Operation Enable<br>0: Stops reception operation<br>1: Enables reception operation<br>The receive operation is stopped by setting the UCnRXE bit to 0. Therefore, even if<br>the prescribed data is transferred, no reception completion interrupt is output and the<br>UARTCn reception data register (UCnRX) is not updated. Since the UCnRXE bit is<br>synchronized using the operating clock, to initialize the reception unit, set UCnRXE<br>from 0 to 1, and 2 clocks later, the reception enabled status is entered.<br>Note: When UCnPWR bit = 0, the value written to the UCnRXE bit is ignored. |
| 4               | UCnDIR   | Transfer Direction Selection<br>0: MSB-first transfer<br>1: Data is sent/received with LSB first<br><b>Note:</b> This bit can be rewritten only when UCnPWR = 0 or UCnTXE = UCnRXE = 0.                                                                                                                                                                                                                                                                                                                                                                                                                             |

RENESAS

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                  |   |                     |                           |  |  |  |
|-----------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------|---------------------------|--|--|--|
| 3               | UCnPS1   |                                                                                                                                                                                                                                                                                                           |   |                     |                           |  |  |  |
| 2               | UCnPS0   |                                                                                                                                                                                                                                                                                                           |   | Parity S            | Selection                 |  |  |  |
|                 |          | UCnPS1 UCnPS0                                                                                                                                                                                                                                                                                             |   | During Transmission | During Reception          |  |  |  |
|                 |          | 0                                                                                                                                                                                                                                                                                                         | 0 | No parity output    | Reception with no parity  |  |  |  |
|                 |          | 0                                                                                                                                                                                                                                                                                                         | 1 | 0 parity output     | Reception with 0 parity   |  |  |  |
|                 |          | 1                                                                                                                                                                                                                                                                                                         | 0 | Odd parity output   | Odd parity check          |  |  |  |
|                 |          | 1 1 Even parity output Even parity check                                                                                                                                                                                                                                                                  |   |                     |                           |  |  |  |
|                 |          | <ul> <li>not performed. Therefore, since the UCnSTR.UCnPE bit is not set, error interrupt is output.</li> <li>2. When transmission and reception are performed in the LIN format, s UCnPS[1:0] bits to 00B.</li> <li>3. This bit can be rewritten only when UCnPWR = 0 or UCnTXE = UCnRXE = 0.</li> </ul> |   |                     |                           |  |  |  |
| 1               | UCnDL    | 0: 7 bits<br>1: 8 bits                                                                                                                                                                                                                                                                                    |   |                     |                           |  |  |  |
| 0               | UCnSL    | Stop Bit Leng<br>0: 1 bit<br>1: 2 bits<br>Note: This I                                                                                                                                                                                                                                                    |   |                     | 0 or UCnTXE = UCnRXE = 0. |  |  |  |

#### Table 11-2 UCnCTL0 register contents (2/2)

# (2) UCnCTL1 - UARTCn control register 1

This register controls the Baud Rate Generator. For details see "UCnCTL1 - UARTCn control register 1" on page 271.

# (3) UCnCTL2 - UARTCn control register 2

This register controls the Baud Rate Generator. For details see *"UCnCTL2 - UARTCn control register 2" on page 272.* 



| (4)           | UCnOPT0 - UARTCn option control register 0<br>The UCnOPT0 register is an 8-bit register that controls the serial transfer<br>operation of the UCRTCn register. |        |        |         |         |         |        |        |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|---------|---------|---------|--------|--------|
| Access        | This register can be read/written in 8-bit or 1-bit units.                                                                                                     |        |        |         |         |         |        |        |
| Address       | UC0OPT0: FFFFFA03 <sub>H</sub><br>UC1OPT0: FFFFFA23 <sub>H</sub><br>UC2OPT0: FFFFFA43 <sub>H</sub>                                                             |        |        |         |         |         |        |        |
| Initial Value | 14 <sub>H</sub> . This register is initialized by any reset.                                                                                                   |        |        |         |         |         |        |        |
|               | 7                                                                                                                                                              | 6      | 5      | 4       | 3       | 2       | 1      | 0      |
| UCnOPT0       | UCnSRF                                                                                                                                                         | UCnSRT | UCnSTT | UCnSLS2 | UCnSLS1 | UCnSLS0 | UCnTDL | UCnRDL |
|               | R                                                                                                                                                              | R/W    | R/W    | R/W     | R/W     | R/W     | R/W    | R/W    |

| Table 11-3 | UCnOPT0 register contents (1/2) |  |
|------------|---------------------------------|--|
|            |                                 |  |

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7               | UCnSRF   | <ul> <li>SBF Reception Flag</li> <li>0: When UCnCTL0.UCnPWR = 0 and UCnCTL0.UCnRXE = 0 are set to 1. Also upon normal end of SBF reception.</li> <li>1: During SBF reception</li> <li>SBF (Sync Brake Field) reception is judged during LIN communication.</li> <li>The UCnSRF bit is held high when a SBF reception error occurs, and then SBF reception is started again.</li> </ul>                                                                                         |
| 6               | UCnSRT   | <ul> <li>SBF Reception Trigger</li> <li>0: -</li> <li>1: SBF reception trigger</li> <li>For SBF reception, set the UCnSRT bit (to 1) to enable reception.</li> <li>Note: 1. When this bit is read, always "0" is returned.</li> <li>2. Set the UCnSRT bit when UCnCTL0.UCnPWR = 1 and UCnCTL0.UCnRXE = 1.</li> </ul>                                                                                                                                                           |
| 5               | UCnSTT   | <ul> <li>SBF Transmission Trigger <ul> <li>0: -</li> <li>1: SBF transmission trigger</li> </ul> </li> <li>This bit triggers the SBF transmission during LIN communication.</li> <li>Note: 1. When this bit is read, always "0" is returned.</li> <li>2. Set the UCnSTT bit when UCnCTL0.UCnPWR = 1 and UCnCTL0.UCnTXE = 1.</li> <li>3. Before starting the SBF transmission by UCnSTT = 1 it has to be ensured that no data transfer is ongoing: UCnSTR.UCnTSF = 0.</li> </ul> |



| Bit<br>position | Bit name    | Function                                                                                                       | Function                                                                                                                                                       |                |                                                                            |  |  |  |
|-----------------|-------------|----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------------------------------------------------------------------|--|--|--|
| 4 to 2          | UCnSLS[2:0] | SBF Lengt                                                                                                      | n Selection                                                                                                                                                    |                |                                                                            |  |  |  |
|                 |             | UCnSLS                                                                                                         | 2 UCnSLS1                                                                                                                                                      | UCnSLS0        | SBF Length Selection                                                       |  |  |  |
|                 |             | 1                                                                                                              | 0                                                                                                                                                              | 1              | 13-bit output (reset value)                                                |  |  |  |
|                 |             | 1                                                                                                              | 1                                                                                                                                                              | 0              | 14-bit output                                                              |  |  |  |
|                 |             | 1                                                                                                              | 1                                                                                                                                                              | 1              | 15-bit output                                                              |  |  |  |
|                 |             | 0                                                                                                              | 1                                                                                                                                                              | 0              | 16-bit output                                                              |  |  |  |
|                 |             | 0                                                                                                              | 17-bit output                                                                                                                                                  |                |                                                                            |  |  |  |
|                 |             | 0                                                                                                              | 0                                                                                                                                                              | 0              | 18-bit output                                                              |  |  |  |
|                 |             | 0                                                                                                              | 1                                                                                                                                                              | 1              | 19-bit output                                                              |  |  |  |
|                 |             | 1                                                                                                              | 0                                                                                                                                                              | 0              | 20-bit output                                                              |  |  |  |
|                 |             | <b>Note:</b> Setting of the UCnSLS[2:0] bits is permitted only when UCnCTL0.UCnPWR = 0, or UCnCTL0.UCnTXE = 0. |                                                                                                                                                                |                |                                                                            |  |  |  |
| 1               | UCnTDL      | 0: Norma<br>1: Inverte                                                                                         | Transmit Data Level<br>0: Normal output of transfer data<br>1: Inverted output of transfer data                                                                |                |                                                                            |  |  |  |
|                 |             | Note: Set                                                                                                      |                                                                                                                                                                | nTDL bit is pe | inverted using the UCnTDL bit.<br>rmitted only when UCnCTL0.UCnPWR = 0, or |  |  |  |
| 0               | UCnRDL      | 0: Norma<br>1: Inverte<br>• The valu                                                                           | eceive Data Level<br>b: Normal input of transfer data<br>: Inverted input of transfer data<br>The value of the RXDCn pin can be inverted using the UCnRDL bit. |                |                                                                            |  |  |  |
|                 |             |                                                                                                                | nCTL0.UCnRX                                                                                                                                                    |                |                                                                            |  |  |  |

# Table 11-3 UCnOPT0 register contents (2/2)



#### (5) UCnOPT1 - UARTCn option control register 1

The UCnOPT1 register is an 8-bit register that controls the extension bit operation of the UARTCn.

Access This register can be read/written in 8-bit or 1-bit units.

# Address UC0OPT1: FFFFFA0A<sub>H</sub> UC1OPT1: FFFFFA2A<sub>H</sub> UC2OPT1: FFFFFA4A<sub>H</sub>

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|         | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|---------|---|---|---|---|---|---|---|--------|
| UCnOPT1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | UCnEBE |
|         | R | R | R | R | R | R | R | R/W    |

#### Table 11-4 UCnOPT1 register contents

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                        |
|-----------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0               | UCnEBE   | <ul> <li>Extension Bit Operation Enable</li> <li>0: Extension bit operation disabled. Transfer data length set by UCnCTL0.UCnCL.</li> <li>1: Extension bit operation enabled.</li> <li>During extension bit operation a 9-th data bit is sent or received instead of the parity bit.</li> </ul> |
|                 |          | Note: Extension bit operation is only effective when the parity selection is set to no parity (UCnCTL0.UCnPS[1:0] = 00B), and the character length is set to 8 bits (UCnCTL0.UCnCL = 1). In all other cases the setting of UCnEBE bit is ignored.                                               |

|        | Regis    | ter Bit Set | tings | Data Format |         |        |                   |      |      |
|--------|----------|-------------|-------|-------------|---------|--------|-------------------|------|------|
| UCnEBE | UCnPS1   | UCnPS0      | UCnCL | UCnSL       | D0 - D6 | D7     | D8                | D9   | D10  |
| 0      | 0        | 0           | 0     | 0           | Data    | Stop   |                   |      |      |
|        |          |             | 0     | 1           | Data    | Stop   | Stop              |      |      |
|        |          |             | 1     | 0           | Data    | Data   | Stop              |      |      |
|        |          |             | 1     | 1           | Data    | Data   | Stop              | Stop |      |
|        | other th | an 00B      | 0     | 0           | Data    | Parity | Stop              |      |      |
|        |          |             | 0     | 1           | Data    | Parity | Stop              | Stop |      |
|        |          |             | 1     | 0           | Data    | Data   | Parity            | Stop |      |
|        |          |             | 1     | 1           | Data    | Data   | Parity            | Stop | Stop |
| 1      | 0        | 0           | 0     | 0           | Data    | Stop   |                   |      |      |
|        |          |             | 0     | 1           | Data    | Stop   | Stop              |      |      |
|        |          |             | 1     | 0           | Data    | Data   | Data <sup>a</sup> | Stop |      |
|        |          |             | 1     | 1           | Data    | Data   | Data <sup>a</sup> | Stop | Stop |
|        | other th | an 00B      | 0     | 0           | Data    | Parity | Stop              |      |      |
|        |          |             | 0     | 1           | Data    | Parity | Stop              | Stop |      |
|        |          |             | 1     | 0           | Data    | Data   | Parity            | Stop |      |
|        |          |             | 1     | 1           | Data    | Data   | Parity            | Stop | Stop |

Insertion of extension bit



#### (6) UARTCn option control register 2 (UCnOPT2)

The UCnOPT2 register is an 8-bit register that displays the UARTCn reception status.

- Access This register can be read only in 8-bit or 1-bit units.
- Address UC0OPT1: FFFFA0B<sub>H</sub> UC1OPT1: FFFFFA2B<sub>H</sub> UC2OPT1: FFFFFA4B<sub>H</sub>

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

| UCnOPT2 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|---------|---|---|---|---|---|---|---|--------|
|         | 0 | 0 | 0 | 0 | 0 | 0 | 0 | UCnRSF |
|         | R | R | R | R | R | R | R | R      |

#### Table 11-6 UCnOPT2 register contents

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                        |
|-----------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0               | UCnRSF   | <ul> <li>Receive Status Flag</li> <li>0: When UCnCTL0.UCnPWR = 0 or UCnCTL0.UCnRXE = 0 has been set, or when the stop bit has been detected.</li> <li>1: During reception, when the start bit has been detected.</li> <li>The UCnRSF flag is set (1) by the start bit detection, and it is cleared (0) by detection of the first stop bit condition.</li> </ul> |
|                 |          | <b>Note:</b> In case of a two stop bit setting (UCnCTL0.UCnSL = 1), the UCnRSF flag is cleared during the first stop bit timing, simultaneously with the reception complete interrupt timing (INTUCnR).                                                                                                                                                         |



# (7) UCnSTR - UARTCn status register

The UCnSTR register is an 8-bit register that displays the UARTCn transfer status and reception error contents.

Access This register can be read/written in 8-bit or 1-bit units. Though the UCnTSF bit is a read-only bit, the UCnPE, UCnFE, and UCnOVE bits can be read and written. However, these bits can only be cleared by writing 0 to it; but cannot be set by writing 1 to it (even if 1 is written to them, the value is retained).

Address UC0STR: FFFFA04<sub>H</sub> UC1STR: FFFFA24<sub>H</sub> UC2STR: FFFFA44<sub>H</sub>

**Initial Value**  $00_{H}$ . This register is cleared by any reset, and when UCnCTL0.PWR = 0 is set.

|        | 7      | 6 | 5 | 4 | 3 | 2     | 1     | 0      |
|--------|--------|---|---|---|---|-------|-------|--------|
| UCnSTR | UCnTSF | 0 | 0 | 0 | 0 | UCnPE | UCnFE | UCnOVE |
|        | R      | R | R | R | R | R/W   | R/W   | R/W    |

| Table 11-7 | UCnSTR register contents (1/2) |
|------------|--------------------------------|
|------------|--------------------------------|

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7               | UCnTSF   | <ul> <li>Transfer Status Flag</li> <li>0: When UCnCTL0.UCnPWR = 0, or<br/>when UCnCTL0.UCnTXE = 0 has been set (transfer disabled), or<br/>when the current transfer is completed and no next data was written to be<br/>transferred from UCnTX, or<br/>when the SBF has been finished after SBF transmission trigger was set.</li> <li>1: When data to be transferred is written to UCnTX register, or<br/>when SBF transmission trigger bit is set (UCnSTT = 1).</li> <li>Note: The UCnTSF bit is always 1 when performing continuous transmission. When<br/>initializing the transmission unit, check that UCnTSF = 0 before performing<br/>initialization. The transmit data is not guaranteed when initialization is<br/>performed while UCnTSF = 1.</li> </ul> |
| 2               | UCnPE    | <ul> <li>Parity Error Flag <ul> <li>When UCnCTL0.UCnPWR = 0, or</li> <li>when UCnCTL0.UCnRXE = 0 has been set (reception disabled), or</li> <li>when 0 has been written</li> </ul> </li> <li>1: When parity of data and parity bit do not match during reception.</li> <li>Note: 1. The operation of the UCnPE bit is controlled by the settings of the UCnCTL0.UCnPS[1:0] bits.</li> <li>2. The UCnPE bit can be read and written, but it can only be cleared by writing 0 to it, but it cannot be set by writing 1 to it. When 1 is written to this bit, the hold status is entered.</li> </ul>                                                                                                                                                                    |



| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1               | UCnFE    | <ul> <li>Framing Error Flag</li> <li>0: When UCnCTL0.UCnPWR = 0, or<br/>when UCnCTL0.UCnRXE = 0 has been set (reception disabled), or<br/>when 0 has been written</li> <li>1: When no stop bit is detected during reception.</li> <li>Note: 1. Only the first bit of the receive data stop bits is checked, regardless of the<br/>value of the UCnCTL0.UCnSL bit.</li> </ul> |
|                 |          | <ol> <li>The UCnFE bit can be read and written, but it can only be cleared by<br/>writing 0 to it, but it cannot be set by writing 1 to it. When 1 is written to this<br/>bit, the hold status is entered.</li> </ol>                                                                                                                                                        |
| 0               | UCnOVE   | <ul> <li>Overrun Error Flag</li> <li>0: When UCnCTL0.UCnPWR = 0, or<br/>when UCnCTL0.UCnRXE = 0 has been set (reception disabled), or<br/>when 0 has been written</li> <li>1: When data has been received into the UCnRX register and the next receive<br/>operation is completed before that receive data has been read.</li> </ul>                                         |
|                 |          | <b>Note:</b> 1. When an overrun error occurs, the data is discarded without the next receive data being written to the receive buffer.                                                                                                                                                                                                                                       |
|                 |          | <ol> <li>The UCnOVE bit can be read and written, but it can only be cleared by<br/>writing 0 to it, but it cannot be set by writing 1 to it. When 1 is written to this<br/>bit, the hold status is entered.</li> </ol>                                                                                                                                                       |

| Table 11-7 | UCnSTR register contents (2/ | 21       |
|------------|------------------------------|----------|
|            |                              | <u> </u> |



#### (8) UCnRX- UARTCn receive data register

The UCnRX register is a 16-bit buffer register that stores parallel data converted by receive shift register. It is overlayed by an 8-bit register UCnRXL on the lower 8 bits, which stores the lower byte of the received data.

The data stored in the receive shift register is transferred to the UCnRX register upon completion of reception of one data frame.

When extension bit operation is enabled (UCnOPT1.UCnEBE = 1) the 9th data bit is received in bit 8 of the UCnRX register. When the extension bit operation is disabled (UCnEBE bit = 0) the data bits are received in the lower byte of the UCnRX register. The lower byte can be read also by 8-bit access of the UCnRXL register.

During LSB-first reception when the data length has been specified as 7 bits and the extension bit operation is disabled, the receive data is transferred to bits 6 to 0 of the UCnRXL register and the MSB always becomes 0. During MSB-first reception, the receive data is transferred to bits 7 to 1 of the UCnRXL register and the LSB always becomes 0.

When an overrun error (UCnOVE bit = 1) occurs, the receive data at this time is not transferred to the UCnRX and UXnRXL register respectively.

Access This register can be read-only in 16-bit units as UCnRX register, or in 8-bit units as UCnRXL register for lower 8 bits.

Address UC0RX, UC0RXL: FFFFFA06<sub>H</sub> UC1RX, UC1RXL: FFFFFA26<sub>H</sub> UC2RX, UC2RXL: FFFFFA46<sub>H</sub>





#### (9) UCnTX - UARTCn transmit data register

The UCnTX register is a 16-bit buffer register used to set transmit data. It is overlayed by an 8-bit register UCnTXL on the lower 8 bits. The UCnTXL register is used for setting the transmit data when 7-bit or 8-bit data character length is specified (UCnEBE bit = 0).

Access This register can be read or written in 16-bit units as UCnTX register, or in 8-bit units as UCnRXL register for lower 8 bits.

| Address | UC0TX, UC0TXL: | FFFFFA08 <sub>H</sub> |
|---------|----------------|-----------------------|
|         | UC1TX, UC1TXL: | FFFFFA28 <sub>H</sub> |
|         | UC2TX, UC2TXL: | FFFFFA48 <sub>H</sub> |

Initial Value 1FF<sub>H</sub> in case of UCnTX register, and  $FF_H$  in case of UCnTXL register, respectively, by any reset.

|        | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8      | 7      | 6 | 5 | 4   | 3   | 2 | 1 | 0 |
|--------|----|----|----|----|----|----|---|--------|--------|---|---|-----|-----|---|---|---|
| UCnTX  |    |    |    |    |    |    | F | Receiv | /e dat | а |   |     |     |   |   |   |
|        |    |    |    |    |    |    |   |        | L      |   |   |     |     |   |   |   |
|        |    |    |    |    |    |    |   |        |        |   |   | UCr | TXL |   |   |   |
|        |    |    |    |    |    |    |   | R      | /W     |   |   |     |     |   |   |   |
|        | 7  | 7  | (  | 6  | Ę  | 5  | 2 | 1      | 3      | 3 | 2 | 2   | -   | 1 | ( | C |
| UCnTXL |    |    |    |    |    |    | F | Receiv | /e dat | a |   |     |     |   |   |   |
|        | •  |    |    |    |    |    |   | R      | /W     |   |   |     |     |   |   |   |



# 11.4 Interrupt Request Signals

The following three interrupt request signals are generated from UARTCn:

- Reception complete interrupt request signal (INTUCnR)
- Receive error interrupt request signal (INTUCnRE)
- Transmission enable interrupt request signal (INTUCnT)

#### (1) Reception complete interrupt request signal (INTUCnR)

A reception complete interrupt request signal is output when data is shifted into the receive shift register and transferred to the UCnRX register in the reception enabled status.

In case of erroneous reception, the reception error interrupt INTUanRE is generated instead of INTUCnR.

No reception complete interrupt request signal is generated in the reception disabled status.

#### (2) Receive error interrupt request signal (INTUCnRE)

A receive error interrupt request is generated if an error condition occurred during reception, as reflected by UCnSTR.UCnPE (parity error flag), UCnSTR.UCnFE (framing error flag), UCnSTR.UCnOVE (overrun error flag).

Note that INTUCnR and INTUCnRE do exclude each other: upon correct reception of data only INTUCnR is generated. In case of a reception error INTUCnRE is generated only.

#### (3) Transmission enable interrupt request signal (INTUCnT)

If transmit data is transferred from the UCnTX register to the UCRTCn transmit shift register with transmission enabled, the transmission enable interrupt request signal is generated.



# 11.5 Operation

# 11.5.1 Data format

Full-duplex serial data reception and transmission is performed.

As shown in the figures below, one data frame of transmit/receive data consists of a start bit, character bits, parity bit, and stop bit(s).

Specification of the character bit length within 1 data frame, parity selection, specification of the stop bit length, and specification of MSB/LSB-first transfer are performed using the UCnCTL0 register. UARTCn features additionally the extension bit operation for a ninth transfer data bit, which can be specified in the UCnOPT1 register.

Moreover, control of UART output/inverted output for the TXDCn bit is performed using the UCnOPT0.UCnTDL bit.

- Start bit.....1 bit
- Character bits......7 bits/8 bits/9 bits
- Parity bit .....Even parity/odd parity/0 parity/no parity
- Stop bit .....1 bit/2 bits

Note Extension bit operation presumes no parity setting.

#### (1) UARTC transmit/receive data format

(a) 8-bit data length, LSB first, even parity, 1 stop bit, transfer data: 55H



#### (b) 8-bit data length, MSB first, even parity, 1 stop bit, transfer data: 55H





# (c) 8-bit data length, MSB first, even parity, 1 stop bit, transfer data: 55H, TXDCn inversion



#### (d) 7-bit data length, LSB first, odd parity, 2 stop bits, transfer data: 36H



#### (e) 8-bit data length, LSB first, no parity, 1 stop bit, transfer data: 87H

| -                |    |    |    | 1 data | frame |    |    |    |             |  |
|------------------|----|----|----|--------|-------|----|----|----|-------------|--|
| <br>Start<br>bit | D0 | D1 | D2 | D3     | D4    | D5 | D6 | D7 | Stop<br>bit |  |

#### (f) 9-bit data length, LSB first, no parity, 1 stop bit, transfer data: 155H





### 11.5.2 SBF transmission/reception format

The UARTC has an SBF (Sync Break Field) transmission/reception control function to enable use of the LIN function.

About LIN LIN stands for Local Interconnect Network and is a low-speed (1 to 20 kbps) serial communication protocol intended to aid the cost reduction of an automotive network.

LIN communication is single-master communication, and up to 15 slaves can be connected to one master.

The LIN slaves are used to control the switches, actuators, and sensors, and these are connected to the LIN master via the LIN network.

Normally, the LIN master is connected to a network such as CAN (Controller Area Network).

In addition, the LIN bus uses a single-wire method and is connected to the nodes via a transceiver that complies with ISO9141.

In the LIN protocol, the master transmits a frame with baud rate information and the slave receives it and corrects the baud rate error. Therefore, communication is possible when the baud rate error in the slave is  $\pm 15\%$  or less.

*Figure 11-2* and *Figure 11-3* outline the transmission and reception manipulations of LIN.



Figure 11-2 LIN transmission manipulation outline

- Note 1. The interval between each field is controlled by software.
  - SBF output is performed by hardware. The output width is the bit length set by the UCnOPT0.UCnSLS2 to UCnOPT0.UCnSLS0 bits. If even finer output width adjustments are required, such adjustments can be performed using the UCnCTLn.UCnBRS7 to UCnCTLn.UCnBRS0 bits.
  - 3. 80H transfer in the 8-bit mode is substituted for the wakeup signal frame.
  - A transmission enable interrupt request signal (INTUCnT) is output at the start of each transmission. The INTUCnT signal is also output at the start of each SBF transmission.





Figure 11-3 LIN reception manipulation outline

- Note 1. The wakeup signal is sent by the pin edge detector, UARTCn is enabled, and the SBF reception mode is set.
  - 2. The receive operation is performed until detection of the stop bit. Upon detection of SBF reception of 11 or more bits, normal SBF reception end is judged, and an interrupt signal is output. Upon detection of SBF reception of less than 11 bits, an SBF reception error is judged, no interrupt signal is output, and the mode returns to the SBF reception mode.
  - 3. If SBF reception ends normally, an interrupt request signal is output. The timer is enabled by an SBF reception complete interrupt. Moreover, error detection for the UCnSTR.UCnOVE, UCnSTR.UCnPE, and UCnSTR.UCnFE bits is suppressed and UART communication error detection processing and UARTCn receive shift register and data transfer of the UCnRX register are not performed. The UARTCn receive shift register holds the initial value, FFH.
  - 4. The RXDCn pin is connected to TI (capture input) of the timer, the transfer rate is calculated, and the baud rate error is calculated. The value of the UCnCTL2 register obtained by correcting the baud rate error after dropping UARTC enable is set again, causing the status to become the reception status.
  - Check-sum field distinctions are made by software. UARTCn is initialized following CSF reception, and the processing for setting the SBF reception mode again is performed by software.



### 11.5.3 SBF transmission

When the UCnCTL0.UCnPWR bit = UCnCTL0.UCnTXE bit = 1, the transmission enabled status is entered, and SBF transmission is started by setting (to 1) the SBF transmission trigger (UCnOPT0.UCnSTT bit).

Thereafter, a low level width of bits 13 to 20 specified by the UCnOPT0.UCnSLS2 to UCnOPT0.UCnSLS0 bits is output. A transmission enable interrupt request signal (INTUCnT) is generated upon SBF transmission start. Following the end of SBF transmission, the UCnSTT bit is automatically cleared. Thereafter, the UART transmission mode is restored.

Transmission is suspended until the data to be transmitted next is written to the UCnTX register, or until the SBF transmission trigger (UCnSTT bit) is set.





### 11.5.4 SBF reception

The reception enabled status is achieved by setting the UCnCTL0.UCnPWR bit to 1 and then setting the UCnCTL0.UCnRX bit to 1.

The SBF reception wait status is set by setting the SBF reception trigger (UCnOPT0.UCnSTR bit) to 1.

In the SBF reception wait status, similarly to the UART reception wait status, the RXDCn pin is monitored and start bit detection is performed.

Following detection of the start bit, reception is started and the internal counter counts up according to the set baud rate.

When a stop bit is received, if the SBF width is 11 or more bits, normal processing is judged and a reception complete interrupt request signal (INTUCnR) is output. The UCnOPT0.UCnSRF bit is automatically cleared and SBF reception ends. Error detection for the UCnSTR.UCnOVE, UCnSTR.UCnPE, and UCnSTR.UCnFE bits is suppressed and UART communication error detection processing is not performed. Moreover, data transfer of the UARTCn reception shift register and UCnRX register is not performed and FFH, the initial value, is held. If the SBF width is 10 or fewer bits, reception is terminated as error processing without outputting an interrupt, and the SBF reception mode is returned to. The UCnSRF bit is not cleared at this time.



#### (a) Normal SBF reception (detection of stop bit in more than 10.5 bits)



#### (b) SBF reception error (detection of stop bit in 10.5 or fewer bits)





### 11.5.5 UART transmission

The transmission enabled status is set by setting UCnCTL0.UCnTXE to 1, after UCnCTL0.UCnPWR was set to 1, and transmission is started by writing transmit data to the UCnTX register. The start bit, parity bit, and stop bit are automatically added.

The data in the UCnTX register is transferred to the UARTCn transmit shift register upon the start of the transmit operation.

A transmission enable interrupt (INTUCnT) is generated upon completion of transmission of the data of the UCnTX register to the UARTCn transmit shift register, and thereafter the contents of the UARTCn transmit shift register are output to the TXDCn pin LSB first.

Write of the next transmit data to the UCnTX register is enabled by generating the INTUCnT signal.

Continuous transmission is enabled by writing the data to be transmitted next to the UCnTX register during transfer.

|         | Start<br>bit | D0 | D1 | D2 | D3 | D4 | D5 | D6 | D7 | Parity<br>bit | Stop<br>bit |
|---------|--------------|----|----|----|----|----|----|----|----|---------------|-------------|
| INTUCnT |              |    |    |    |    |    |    |    |    |               |             |



Note LSB first



#### 11.5.6 Continuous transmission procedure

UARTCn can write the next transmit data to the UCnTX register when the UARTCn transmit shift register starts the shift operation. The transfer timing of the UARTCn transmit shift register can be judged from the transmission enable interrupt (INTUCnT). Transmission can be performed without interruption even during interrupt processing following the transmission of 1 data frame via the INTUCnT signal, and an efficient communication rate can thus be achieved.

During continuous transmission, overrun (the completion of the next transmission before the first transmission completion processing has been executed) may occur.

An overrun can be detected by incorporating a program that can count the number of transmit data and by referencing transfer status flag (UCnSTR.UCnTSF).

**Caution** During continuous transmission execution, perform initialization after checking that the UCnSTR.UCnTSF bit is 0. The transmit data cannot be guaranteed when initialization is performed while the UCnTSF bit is 1.



Figure 11-6 Continuous transmission processing flow





Figure 11-7 Continuous transmission operation timing —transmission start



Figure 11-8 Continuous transmission operation timing—transmission end



## 11.5.7 UART reception

The reception wait status is set by setting UCnCTL0.UCnPWR to 1 and then setting UCnCTL0.UCnRXE to 1. In the reception wait status, the RXDCn pin is monitored and start bit detection is performed.

Start bit detection is performed using a two-step detection routine.

First, an 8-bit counter starts upon detection of the falling edge of the RXDCn pin. When the 8-bit counter has counted the UCnCTL2 register setting value, the level of the RXDCn pin is monitored again (corresponds to the — mark in Figure 15-19). If the RXDCn pin is low level at this time too, a start bit is recognized. After a start bit has been recognized, the receive operation starts, and serial data is saved to the UARTCn receive shift register according to the set baud rate. Additionally the flag UCnOPT2.UCnRSF is set (1) to indicate the receive operation status.

When the reception complete interrupt (INTUCnR) is output upon reception of the stop bit, the data of the UARTCn receive shift register is written to the UCnRX register, and the UCnRSF flag is cleared (0) simultaneously. However, if an overrun error occurs (UCnOVE bit = 1), the receive data at this time is not written to the UCnRX register, and a reception error interrupt (INTUCnRE) is output.

Even if a parity error (UCnPE bit = 1) or a framing error (UCnFE bit = 1) occurs during reception, reception continues until the stop bit reception position, but a reception error interrupt (INTUCnRE) is output following reception completion.



Figure 11-9 UART reception



Caution 1. Be sure to read the UCnRX register even when a reception error occurs. If the UCnRX register is not read, an overrun error occurs during reception of the next data, and reception errors continue occurring indefinitely. 2. The operation during reception is performed assuming that there is only one stop bit. A second stop bit is ignored. 3. When reception is completed, read the UCnRX register after the reception complete interrupt request signal (INTUCnR) has been generated, and clear the UCnPWR or UCnRXE bit to 0. If the UCnPWR or UCnRXE bit is cleared to 0 before the INTUCnR signal is generated, the read value of the UCnRX register cannot be guaranteed. 4. If receive completion processing (INTUCnR signal generation) of UARTCn and the UCnPWR bit = 0 or UCnRXE bit = 0 conflict, the INTUCnR signal may be generated in spite of these being no data stored in the UCnRX register. To complete reception without waiting INTUCnR signal generation, be sure

To complete reception without waiting INTUCnR signal generation, be sure to clear (0) the interrupt request flag (UCnRIF) of the UCnRIC register, after setting (1) the interrupt mask flag (UCnRMK) of the interrupt control register (UCnRIC) and then set (1) the UCnPWR bit = 0 or UCnRXE bit = 0.



### 11.5.8 Reception errors

Errors during a receive operation are of three types: parity errors, framing errors, and overrun errors. Data reception result error flags are set in the UCnSTR register and a reception error interrupt request signal (INTUCnRE) is output when an error occurs.

It is possible to ascertain which error occurred during reception by reading the contents of the UCnSTR register.

Clear the reception error flag by writing 0 to it after reading it.

| Error flag | Reception error | Cause                                                                     |
|------------|-----------------|---------------------------------------------------------------------------|
| UCnPE      | Parity error    | Received parity bit does not match the setting                            |
| UCnFE      | Framing error   | Stop bit not detected                                                     |
| UCnOVE     | Overrun error   | Reception of next data completed before data was read from receive buffer |

Table 11-8 Reception error causes

- **Caution 1.** Be sure to read the UCnRX register even when a reception error occurs. If the UCnRX register is not read, an overrun error occurs during reception of the next data, and reception errors continue occurring indefinitely.
  - 2. The operation during reception is performed assuming that there is only one stop bit. A second stop bit is ignored.
  - Note Note that even in case of a parity or framing error, data is transferred from the receive shift register to the receive data register UCnRX. Consequently the data from UCnRX must be read. Otherwise an overrun error UCnSTR.UCnOVE will occur at reception of the next data.

In case of an overrun error, the receive shift register data is not transferred to UCnRX, thus the previous data is not overwritten.

### 11.5.9 Parity types and operations

**Caution** When using the LIN function, fix the UCnPS1 and UCnPS0 bits of the UCnCTL0 register to 00.



The parity bit is used to detect bit errors in the communication data. Normally the same parity is used on the transmission side and the reception side.

In the case of even parity and odd parity, it is possible to detect odd-count bit errors. In the case of 0 parity and no parity, errors cannot be detected.

#### (1) Even parity

• During transmission

The number of bits whose value is "1" among the transmit data, including the parity bit, is controlled so as to be an even number. The parity bit values are as follows.

- Odd number of bits whose value is "1" among transmit data: 1
- Even number of bits whose value is "1" among transmit data: 0
- During reception

The number of bits whose value is "1" among the reception data, including the parity bit, is counted, and if it is an odd number, a parity error is output.

#### (2) Odd parity

• During transmission

Opposite to even parity, the number of bits whose value is "1" among the transmit data, including the parity bit, is controlled so that it is an odd number. The parity bit values are as follows.

- Odd number of bits whose value is "1" among transmit data: 0
- Even number of bits whose value is "1" among transmit data: 1
- During reception

The number of bits whose value is "1" among the receive data, including the parity bit, is counted, and if it is an even number, a parity error is output.

#### (3) 0 parity

During transmission, the parity bit is always made 0, regardless of the transmit data.

During reception, parity bit check is not performed. Therefore, no parity error occurs, regardless of whether the parity bit is 0 or 1.

#### (4) No parity

No parity bit is added to the transmit data.

Reception is performed assuming that there is no parity bit. No parity error occurs since there is no parity bit.



### 11.5.10 Receive data noise filter

This filter samples the RXDCn pin using the selected clock ( $f_{XCLK}$ ).

When the same sampling value is read twice, the match detector output changes and the RXDCn signal is sampled as the input data.

Furthermore the processing that goes on within the receive operation is delayed by 2 clocks in relation to the external signal status (refer to the circuit as shown in *Figure 11-10*).



Figure 11-10 Noise filter circuit



# 11.6 Baud Rate Generator

The dedicated baud rate generator consists of a source clock selector block and an 8-bit programmable counter, and generates a serial clock during transmission and reception with UARTCn. Regarding the serial clock, a dedicated baud rate generator output can be selected for each channel.

There is an 8-bit counter for transmission and another one for reception.

#### (1) Baud rate generator configuration



Figure 11-11 Configuration of baud rate generator

|      |                  |                     |                 | • · · ·                  |   |
|------|------------------|---------------------|-----------------|--------------------------|---|
| Note | PCI K0 to PCI K9 | peripheral clocks ( | reter to "Clock | Generator" on page 148): | · |
|      |                  |                     | 10101 10 01001  | acherater en page i leji | ÷ |

| PCLK    | 0  | 1  | 2 | 3 | 4 | 5 | 6   | 7    | 8     | 9      |
|---------|----|----|---|---|---|---|-----|------|-------|--------|
| f [MHz] | 32 | 16 | 8 | 4 | 2 | 1 | 0.5 | 0.25 | 0.125 | 0.0625 |

#### (a) Base clock (Clock)

When the UCnCTL0.UCnPWR bit is 1, the clock selected by the UCnCTL1.UCnCKS[3:0] bits is supplied to the 8-bit counter. This clock is called the base clock. When the UCnPWR bit = 0, the clock is fixed to the low level.

#### (b) Serial clock generation

A serial clock can be generated by setting the UCnCTL1 register and the UCnCTL2 register.

The base clock is selected by bits UCnCTL1.UCnCKS[3:0] bits.

The frequency division value for the 8-bit counter can be set using the UCnCTL2.UCnBRS[7:0] bits.



| (2)           | UCnCTL1                           | - UARTC                                                                                            | n contro | l register | 1   |     |     |     |  |  |  |  |
|---------------|-----------------------------------|----------------------------------------------------------------------------------------------------|----------|------------|-----|-----|-----|-----|--|--|--|--|
|               | The UCn(<br>(f <sub>XCLK</sub> ). | The UCnCTL1 register is an 8-bit register that selects the UARTCn base clock $(f_{XCLK})$ .        |          |            |     |     |     |     |  |  |  |  |
| Access        | This regis                        | This register can be read/written in 8-bit units.                                                  |          |            |     |     |     |     |  |  |  |  |
| Address       | UC1CTL1                           | UC0CTL1: FFFFFA01 <sub>H</sub><br>UC1CTL1: FFFFFA21 <sub>H</sub><br>UC2CTL1: FFFFFA41 <sub>H</sub> |          |            |     |     |     |     |  |  |  |  |
| Initial Value | 00 <sub>H</sub> . This            | 00 <sub>H</sub> . This register is cleared by any reset.                                           |          |            |     |     |     |     |  |  |  |  |
|               | 7                                 | 7 6 5 4 3 2 1 0                                                                                    |          |            |     |     |     |     |  |  |  |  |
| UCnCTL1       | 0                                 | 0 0 0 0 UCnCKS3UCnCKS2UCnCKS1UCnCKS0                                                               |          |            |     |     |     |     |  |  |  |  |
|               | R                                 | R                                                                                                  | R        | R          | R/W | R/W | R/W | R/W |  |  |  |  |

Caution Clear the UCnCTL0.UCnPWR bit to 0 before rewriting the UCnCTL1 register.

#### Table 11-9 UCnCTL1 register contents

| Bit<br>position | Bit name    | Function     |                                 |         |            |                                           |  |  |  |  |  |  |
|-----------------|-------------|--------------|---------------------------------|---------|------------|-------------------------------------------|--|--|--|--|--|--|
| 3 to 0          | UCnCKS[3:0] | Base clock s | ase clock selection             |         |            |                                           |  |  |  |  |  |  |
|                 |             | UCnCKS3      | UCnCKS2                         | UCnCKS1 | UCnCKS0    | Base clock (f <sub>XCLK</sub> ) selection |  |  |  |  |  |  |
|                 |             | 0            | 0                               | 0       | 0          | PCLK0 (32 MHz)                            |  |  |  |  |  |  |
|                 |             | 0            | 0                               | 0       | 1          | PCLK1 (16 MHz)                            |  |  |  |  |  |  |
|                 |             | 0            | 0                               | 1       | 0          | PCLK2 (8 MHz)                             |  |  |  |  |  |  |
|                 |             | 0            | 0                               | 1       | 1          | PCLK3 (4 MHz)                             |  |  |  |  |  |  |
|                 |             | 0            | 1                               | 0       | 0          | PCLK4 (2 MHz)                             |  |  |  |  |  |  |
|                 |             | 0            | 1                               | 0       | 1          | PCLK5 (1 MHz)                             |  |  |  |  |  |  |
|                 |             | 0            | 1                               | 1       | 0          | PCLK6 (500 KHz)                           |  |  |  |  |  |  |
|                 |             | 0            | 1                               | 1       | 1          | PCLK7 (250 KHz)                           |  |  |  |  |  |  |
|                 |             | 1            | 0                               | 0       | 0          | PCLK8 (125 KHz)                           |  |  |  |  |  |  |
|                 |             | 1            | 0                               | 0       | 1          | PCLK9 (62.5 KHz)                          |  |  |  |  |  |  |
|                 |             |              | all of                          | hers    |            | setting prohibited                        |  |  |  |  |  |  |
|                 |             |              | s of periphera<br>r" on page 14 |         | LK0 to PCL | (9) refer to chapter "Clock               |  |  |  |  |  |  |



| (3)           | UCnCTL2                       | 2 - UARTO                   | n contro         | l register  | 2           |         |            |         |  |  |  |
|---------------|-------------------------------|-----------------------------|------------------|-------------|-------------|---------|------------|---------|--|--|--|
|               | The UCn<br>the baud           | •                           |                  | •           | •           |         | divisor to | control |  |  |  |
| Access        | This regis                    | ter can be                  | e read/writ      | ten in 8-bi | it units.   |         |            |         |  |  |  |
| Address       | UC0CTL2<br>UC1CTL2<br>UC2CTL2 | : FFFFF                     | 422 <sub>H</sub> |             |             |         |            |         |  |  |  |
| Initial Value | FF <sub>H</sub> . This        | register is                 | s cleared l      | by any res  | et.         |         |            |         |  |  |  |
|               | 7                             | 6                           | 5                | 4           | 3           | 2       | 1          | 0       |  |  |  |
| UCnCTL2       | UCnBRS7                       | UCnBRS6                     | UCnBRS5          | UCnBRS4     | UCnBRS3     | UCnBRS2 | UCnBRS1    | UCnBRS0 |  |  |  |
|               | R/W                           | R/W R/W R/W R/W R/W R/W R/W |                  |             |             |         |            |         |  |  |  |
|               |                               |                             |                  |             |             |         |            |         |  |  |  |
| Caution       | Clear the                     | UCnCTLC                     | .UCnPWI          | R bit to 0, | or clear th | e UCnCT | L0.UCnT>   | (E and  |  |  |  |

Ition Clear the UCnCTL0.UCnPWR bit to 0, or clear the UCnCTL0.UCnTXE and UCnCTL0.UCnRXE bits to 0 before rewriting the UCnCTL2 register.

| Table 11-10 | UCnCTL2 register contents |
|-------------|---------------------------|
|-------------|---------------------------|

| Bit<br>position | Bit name    | Functio     | on                  |             |             |         |         |             |             |                |                           |  |
|-----------------|-------------|-------------|---------------------|-------------|-------------|---------|---------|-------------|-------------|----------------|---------------------------|--|
| 7 to 0          | UCnBRS[7:0] | Baud ra     | aud rate selection  |             |             |         |         |             |             |                |                           |  |
|                 |             | UCn<br>BRS7 | UCn<br>BRS6         | UCn<br>BRS5 | UCn<br>BRS4 |         |         | UCn<br>BRS1 | UCn<br>BRS0 | Default<br>(k) | Serial clock <sup>a</sup> |  |
|                 |             | 0           | 0                   | 0           | 0           | 0       | 0       | -           | -           | -              | Setting<br>prohibited     |  |
|                 |             | 0           | 0                   | 0           | 0           | 0       | 1       | 0           | 0           | 4              | f <sub>XCLK</sub> /4      |  |
|                 |             | 0           | 0                   | 0           | 0           | 0       | 1       | 0           | 1           | 5              | f <sub>XCLK</sub> /5      |  |
|                 |             | 0           | 0                   | 0           | 0           | 0       | 1       | 1           | 0           | 6              | f <sub>XCLK</sub> /6      |  |
|                 |             | :           | :                   | :           | :           | :       | :       | :           | :           | :              | :                         |  |
|                 |             | 1           | 1                   | 1           | 1           | 1       | 1       | 0           | 0           | 252            | f <sub>XCLK</sub> /252    |  |
|                 |             | 1           | 1                   | 1           | 1           | 1       | 1       | 0           | 1           | 253            | f <sub>XCLK</sub> /253    |  |
|                 |             | 1           | 1                   | 1           | 1           | 1       | 1       | 1           | 0           | 254            | f <sub>XCLK</sub> /254    |  |
|                 |             | 1           | 1                   | 1           | 1           | 1       | 1       | 1           | 1           | 255            | f <sub>XCLK</sub> /255    |  |
|                 |             | a) fy       | <sub>(CLK</sub> : C | lock fre    | quency      | selecte | ed by U | CnCTL       | 1.UCn       | CKS[3:0]       |                           |  |

#### (4) Baud rate

The baud rate is obtained by the following equation.

Baud rate = 
$$\frac{f_{xCLK}}{2 \times k}$$
 [bps]

 $f_{xCLK}$  = Clock frequency selected by UCnCTL1.UCnCKS[3:0].

k = Value set using the UCnCTL2.UCnBRS[7:0] bits(k = 4, 5, 6, ..., 255)



| (5)            | Baud rate error                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                     |          |         |     |                        |  |  |  |  |  |  |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------|-----|------------------------|--|--|--|--|--|--|
|                | The baud rate error is obtained by the following equation.                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                     |          |         |     |                        |  |  |  |  |  |  |
|                | Error (%) = $\left(\frac{\text{Actual baud rate (baud rate with error)}}{\text{Target baud rate (correct baud rate)}} - 1\right) \times 100 [\%]$ |                                                                                                                                                                                                                                                                                                                                                                                                     |          |         |     |                        |  |  |  |  |  |  |
| Caution        |                                                                                                                                                   | <ol> <li>The baud rate error during transmission must be within the error tolerance<br/>on the receiving side.</li> </ol>                                                                                                                                                                                                                                                                           |          |         |     |                        |  |  |  |  |  |  |
|                |                                                                                                                                                   | 2. The baud rate error during reception must satisfy the range indicated in <i>"Allowable baud rate range during reception" on page 274.</i>                                                                                                                                                                                                                                                        |          |         |     |                        |  |  |  |  |  |  |
| Example<br>(6) | <ul> <li>UCnCTL<sup>2</sup></li> <li>UCnCTL<sup>2</sup></li> <li>Target baud</li> <li>Actual Baud</li> <li>Baud rate e</li> </ul>                 | <ul> <li>Setting value of <ul> <li>UCnCTL1.UDnCKS[3:0] = 0001<sub>B</sub>: f<sub>XCLK</sub> = PCLK1 = 16 MHz</li> <li>UCnCTL2.UDnBRS[7:0] = 0011 0100<sub>B</sub>: k = 52</li> </ul> </li> <li>Target baud rate = 153,600 bps</li> <li>Actual Baud rate = 16 MHz / (2 × 52) = 153,846 [bps]</li> <li>Baud rate error = (153,846/153,600 - 1) × 100 = 0.160 [%]</li> </ul> Baud rate setting example |          |         |     |                        |  |  |  |  |  |  |
| Table 11-11    | Baud rate ger                                                                                                                                     | nerator sett                                                                                                                                                                                                                                                                                                                                                                                        | ing data |         |     |                        |  |  |  |  |  |  |
|                | Target baud rate [bps]                                                                                                                            | UCnCTL1                                                                                                                                                                                                                                                                                                                                                                                             | fxclk    | UCnCTL2 | k   | Baud rate error<br>[%] |  |  |  |  |  |  |
|                | 600                                                                                                                                               | 08H                                                                                                                                                                                                                                                                                                                                                                                                 | 125 KHz  | 68H     | 104 | 0.16                   |  |  |  |  |  |  |
|                | 1200                                                                                                                                              | 07H                                                                                                                                                                                                                                                                                                                                                                                                 | 250 KHz  | 68H     | 104 | 0.16                   |  |  |  |  |  |  |
|                | 2400                                                                                                                                              | 06H                                                                                                                                                                                                                                                                                                                                                                                                 | 500 KHz  | 68H     | 104 | 0.16                   |  |  |  |  |  |  |
|                | 4800                                                                                                                                              | 05H                                                                                                                                                                                                                                                                                                                                                                                                 | 1 MHz    | 68H     | 104 | 0.16                   |  |  |  |  |  |  |
|                | 9600                                                                                                                                              | 04H                                                                                                                                                                                                                                                                                                                                                                                                 | 2 MHz    | 68H     | 104 | 0.16                   |  |  |  |  |  |  |
|                | 10400                                                                                                                                             | 04H                                                                                                                                                                                                                                                                                                                                                                                                 | 2 MHz    | 60H     | 96  | 0.16                   |  |  |  |  |  |  |
|                | 19200                                                                                                                                             | 03H                                                                                                                                                                                                                                                                                                                                                                                                 | 4 MHz    | 68H     | 104 | 0.16                   |  |  |  |  |  |  |
|                | 31250                                                                                                                                             | 02H                                                                                                                                                                                                                                                                                                                                                                                                 | 8 MHz    | 80H     | 128 | 0.00                   |  |  |  |  |  |  |
|                | 38400                                                                                                                                             | 02H                                                                                                                                                                                                                                                                                                                                                                                                 | 8 MHz    | 68H     | 104 | 0.16                   |  |  |  |  |  |  |
|                | 56000                                                                                                                                             | 01H                                                                                                                                                                                                                                                                                                                                                                                                 | 16 MHz   | 8FH     | 143 | -0.1                   |  |  |  |  |  |  |
|                | 76800                                                                                                                                             | 02H                                                                                                                                                                                                                                                                                                                                                                                                 | 8 MHz    | 1AH     | 52  | 0.16                   |  |  |  |  |  |  |
|                | 125000                                                                                                                                            | 02H                                                                                                                                                                                                                                                                                                                                                                                                 | 8 MHz    | 20H     | 32  | 0.00                   |  |  |  |  |  |  |
|                | 153600                                                                                                                                            | 02H                                                                                                                                                                                                                                                                                                                                                                                                 | 16 MHz   | 1AH     | 52  | 0.16                   |  |  |  |  |  |  |
|                | 250000                                                                                                                                            | 02H                                                                                                                                                                                                                                                                                                                                                                                                 | 8 MHz    | 10H     | 16  | 0.00                   |  |  |  |  |  |  |
|                | 312500                                                                                                                                            | 00H                                                                                                                                                                                                                                                                                                                                                                                                 | 32 MHz   | 33H     | 51  | 0.39                   |  |  |  |  |  |  |
|                | 1000000                                                                                                                                           | 00H                                                                                                                                                                                                                                                                                                                                                                                                 | 32 MHz   | 10H     | 16  | 0.00                   |  |  |  |  |  |  |
|                | 2000000                                                                                                                                           | 00H                                                                                                                                                                                                                                                                                                                                                                                                 | 32 MHz   | 08H     | 8   | 0.00                   |  |  |  |  |  |  |



#### (7) Allowable baud rate range during reception

The baud rate error range at the destination that is allowable during reception is shown below.

**Caution** The baud rate error during reception must be set within the allowable error range using the following equation.



Figure 11-12 Allowable baud rate range during reception

As shown in *Figure 11-12*, the receive data latch timing is determined by the counter set using the UCnCTL2 register following start bit detection. The transmit data can be normally received if up to the last data (stop bit) can be received in time for this latch timing.

When this is applied to 11-bit reception, the following is the theoretical result.

$$FL = (Brate)^{-1}$$

Brate: UARTCn baud rate

k: Setting value of UCnCTL2.UCnBRS[7:0]

FL: 1-bit data length

Latch timing margin: 2 clocks

Minimum allowable transfer rate:

$$FL_{min} = 11 \times FL - \frac{k-2}{2k} \times FL = \frac{21k+2}{2k} \times FL$$

Therefore, the maximum baud rate that can be received by the destination is as follows.

$$BR_{max} = (FL_{min}/11)^{-1} = \frac{22k}{21k+2} \times Brate$$



Similarly, obtaining the following maximum allowable transfer rate yields the following.

$$\frac{10}{11} \times FL_{max} = 11 \times FL - \frac{k+2}{2k} \times FL = \frac{21k-2}{2k} \times FL$$
$$FL_{max} = \frac{21k-2}{20k} \times FL \times 11$$

Therefore, the minimum baud rate that can be received by the destination is as follows.

$$BR_{min} = (FL_{max}/11)^{-1} = \frac{20k}{21k-2} \times Brate$$

Obtaining the allowable baud rate error for UARTCn and the destination from the above-described equations for obtaining the minimum and maximum baud rate values yields the following.

#### Table 11-12 Maximum/Minimum allowable baud rate error

| Division ratio<br>(k) | Maximum allowable<br>baud rate error | Minimum allowable baud rate error |
|-----------------------|--------------------------------------|-----------------------------------|
| 8                     | +3.53%                               | -3.61%                            |
| 20                    | +4.26%                               | -4.31%                            |
| 50                    | +4.56%                               | -4.58%                            |
| 100                   | +4.66%                               | -4.67%                            |
| 255                   | +4.72%                               | -4.73%                            |

- **Note** 1. The reception accuracy depends on the bit count in 1 frame, the input clock frequency, and the division ratio (k). The higher the input clock frequency and the larger the division ratio (k), the higher the accuracy.
  - 2. k: Setting value of UCnCTL2.UCnBRS[7:0]



#### (8) Baud rate during continuous transmission

During continuous transmission, the transfer rate from the stop bit to the next start bit is usually 2 base clocks longer. However, timing initialization is performed via start bit detection by the receiving side, so this has no influence on the transfer result.



Figure 11-13 Transfer rate during continuous transfer

Assuming 1 bit data length: FL; stop bit length: FLstp; and base clock frequency:  $f_{XCLK}$ , we obtain the following equation.

$$FLstp = FL + 2/f_{XCLK}$$

Therefore, the transfer rate during continuous transmission is as follows.

Transfer rate =  $11 \times FL + (2/f_{XCLK})$ 



# 11.7 Cautions

#### (1) UARTCn operation stop

If both of the following actions in UARTCn happen at the same time the INTUCnR signal may be generated inadvertently and no data is stored in the UCnRX register:

- INTUCnR is generated due to completion of a serial receive operation,
- UCnPWR bit or UCnRXE bit of the UCnCTL0 register is cleared (set to 0).
- **Workaround** To avoid the generation of the INTUCnR signal when UCnPWR bit or UCnRXE bit is cleared (set to 0) do the following:
  - 1. Set (set to 1) the interrupt mask flag (UCnRMK) of the interrupt control register (UCnRIC),
  - 2. Clear (set to 0) the UCnPWR bit or UCnRXE bit of the UCnCTL0 register,
  - 3. Clear (set to 0) the interrupt request flag (UCnRIF) of the UCnRIC register.

#### (2) UARTCn receive error interrupt

If both of the following actions in UARTCn happen at the same time the INTUCnRE may not be generated and the INTUCnR signal may be generated inadvertently:

- INTUCnRE is generated due to erroneous frame reception.
- UCnPWR bit or UCnRXE bit of control register UCnCTL0 is cleared to 0.

#### **Workaround** 1. Set the interrupt mask flag UCnRMK of the interrupt control register UCnRIC to 1 and set the interrupt mask flag UCnREMK of the interrupt control register UCnREIC.

- 2. Clear the UCnPWR bit or UCnRXE bit of the UCnCTL0 register to 0.
- 3. Clear the interrupt request flag UCnRIF of the UCnRIC register and clear the interrupt request flag UCnREIF of the UCnREIC register to 0.



# Chapter 12 Clocked Serial Interface (CSIB)

The microcontroller has two instances of the Clocked Serial Interface CSIB: CSIB0 to CSIB1.

Note Throughout this chapter, the individual instances of CSIB are identified by "n" (n = 0, 1).

# 12.1 Features

- Transfer rate: Maximum 8 Mbps
- Master mode and slave mode selectable
- 8-bit to 16-bit transfer, 3-wire serial interface
- 3 interrupt request signals (INTCBnT, INTCBnR, INTCBnRE)
- Serial clock and data phase switchable
- Transfer data length selectable in 1-bit units between 8 and 16 bits
- Transfer data MSB-first/LSB-first switchable

| • | 3-wire transfer |
|---|-----------------|
|   |                 |

•

| SOBn:  | Serial data output        |
|--------|---------------------------|
| SIBn:  | Serial data input         |
| SCKBn: | Serial clock input/output |

Transmission mode, reception mode, and transmission/reception mode specifiable

- Slave select function supported
   SSBn: Serial slave select input
- DMA support
- Dedicated baud rate generator for each interface instance



# 12.2 Configuration



The following shows the block diagram of CSIBn.

Figure 12-1 Block diagram of CSIBn

Note PCLK1 to PCLK6: peripheral clocks (refer to "Clock Generator" on page 148):

| PCLK    | 1  | 2 | 3 | 4 | 5 | 6   |
|---------|----|---|---|---|---|-----|
| f [MHz] | 16 | 8 | 4 | 2 | 1 | 0.5 |

Additional clocks are generated by dedicated baud rate generators BRG0/BRG1.

CSIBn includes the following hardware.

#### Table 12-1 Configuration of CSIBn

| Item              | Configuration                                                                                                                                    |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Registers         | CSIBn receive data register (CBnRX0)<br>CSIBn transmit data register (CBnTX0)                                                                    |
| Control registers | CSIBn control register 0 (CBnCTL0)<br>CSIBn control register 1 (CBnCTL1)<br>CSIBn control register 2 (CBnCTL2)<br>CSIBn status register (CBnSTR) |



#### (1) CBnRX0 - CSIBn receive data register

The CBnRX0 register is a 16-bit buffer register that holds receive data. The receive operation is started by reading the CBnRX0 register in the reception enabled status.

- Access This register can be read-only in 16-bit units. If the transfer data length is 8 bits, the lower 8 bits of this register are read-only in 8-bit units as the CBnRX0L register.
- Address CB0RX0: FFFFFD04<sub>H</sub> CB1RX0: FFFFFD24<sub>H</sub>

Initial Value 0000<sub>H</sub>. This register is cleared by any reset. In addition to reset input, the CBnRX0 register can be initialized by clearing (to 0) the CBnPWR bit of the CBnCTL0 register.

|        | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8      | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------|----|----|----|----|----|----|---|--------|--------|---|---|---|---|---|---|---|
| CBnRX0 |    |    |    |    |    |    | F | Receiv | /e dat | а |   |   |   |   |   |   |
|        |    |    |    |    |    |    |   | F      | 7      |   |   |   |   |   |   |   |

#### (2) CBnTX0 - CSIBn transmit data register

The CBnTX0 register is a 16-bit buffer register used to write the CSIBn transfer data. The transmit operation is started by writing data to the CBnTX register in the transmission enabled status.

- Access This register can be read/written in 16-bit units. If the transfer data length is 8 bits, the lower 8 bits of this register are read/write in 8-bit units as the CBnTX0L register.
- Address CB0TX0: FFFFFD06<sub>H</sub> CB1TX0: FFFFFD26<sub>H</sub>

# Initial Value 0000<sub>H</sub>. This register is cleared by any reset. In addition to reset input, the CBnTX0 register can be initialized by clearing (to 0) the CBnPWR bit of the CBnCTL0 register.

|        | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8      | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------|----|----|----|----|----|----|---|--------|---------|---|---|---|---|---|---|---|
| CBnTX0 |    |    |    |    |    |    | Т | iransn | nit dat | a |   |   |   |   |   |   |
|        |    |    |    |    |    |    |   | R/     | W       |   |   |   |   |   |   |   |

Note The communication start conditions are shown below:

- Transmission mode (CBnTXE bit = 1, CBnRXE bit = 0): Write to CBnTX0 register
- Transmission/reception mode (CBnTXE bit = 1, CBnRXE bit = 1): Write to CBnTX0 register
- Reception mode (CBnTXE bit = 0, CBnRXE bit = 1): Read from CBnRX0 register



# 12.3 CSIB Control Registers

The following registers are used to control CSIBn.

- CSIBn control register 0 (CBnCTL0)
- CSIBn control register 1 (CBnCTL1)
- CSIBn control register 2 (CBnCTL2)
- CSIBn status register (CBnSTR)

#### (1) CBnCTL0 - CSIBn control register 0

CBnCTL0 is a register that controls the CSIBn serial transfer operation.

Access This register can be read/written in 8-bit or 1-bit units.

Address CB0CTL0: FFFFFD00<sub>H</sub> CB1CTL0: FFFFFD20<sub>H</sub>

Initial Value 01<sub>H</sub>

|         | 7      | 6                   | 5                   | 4                   | 3 | 2 | 1                   | 0      |
|---------|--------|---------------------|---------------------|---------------------|---|---|---------------------|--------|
| CBnCTL0 | CBnPWR | CBnTXE <sup>a</sup> | CBnRXE <sup>a</sup> | CBnDIR <sup>a</sup> | 0 | 0 | CBnTMS <sup>a</sup> | CBnSCE |
|         | R/W    | R/W                 | R/W                 | R/W                 | R | R | R/W                 | R/W    |

<sup>a)</sup> These bits can only be rewritten when the CBnPWR bit = 0. However, CBnPWR bit = 1 can also be set at the same time as rewriting these bits.

| Table 12-2 CBnCTL0 register contents | s (1/2) |  |
|--------------------------------------|---------|--|
|--------------------------------------|---------|--|

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                |
|-----------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7               | CBnPWR   | CSIBn operation disable/enable:<br>0: Disable CSIBn operation and reset the CSIBn registers<br>1: Enable CSIBn operation<br>The CBnPWR bit controls the CSIBn operation and resets the internal circuit.<br>Note: To abort reception/transmission forcibly, clear the CBnPWR bit (not the                                               |
|                 |          | CBnTXE bit or CBnRXE bit) to 0. The clock output stops at this time.                                                                                                                                                                                                                                                                    |
| 6               | CBnTXE   | Transmit operation disable/enable:<br>0: Disable transmit operation<br>1: Enable transmit operation<br>The SOBn output is low level and transmission is disabled when the CBnTXE bit is 0.                                                                                                                                              |
| 5               | CBnRXE   | Receive operation disable/enable:<br>0: Disable receive operation<br>1: Enable receive operation<br>When the CBnRXE bit is cleared to 0, no reception complete interrupt is output even<br>when the prescribed data is transferred in order to disable the receive operation, and<br>the receive data (CBnRX0 register) is not updated. |
| 4               | CBnDIR   | Transfer direction mode specification (MSB/LSB):<br>0: MSB first transfer<br>1: LSB first transfer                                                                                                                                                                                                                                      |
| 1               | CBnTMS   | Transfer mode specification (MSB/LSB):<br>0: Single transfer mode<br>1: Continuous transfer mode                                                                                                                                                                                                                                        |



| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0               | CBnSCE   | <ul> <li>Specification of start transfer disable/enable:</li> <li>0: Communication start trigger invalid</li> <li>1: Communication start trigger valid</li> <li>This bit controls the behaviour upon a communication start trigger in master/slave single/continuous reception mode.</li> <li>To start the reception operation set the bit to 1 before performing a dummy read to the CBnRX0 register.</li> <li>To stop the reception operation in</li> <li>Single reception mode clear the CBnSCE bit before reading the final data from the CBnRX0 register.</li> <li>Continuous reception mode clear the CBnSCE bit at least one communication clock before the completion of the last data reception. Otherwise the next communication operation is automatically started</li> <li>For details refer to chapter 12.4"Operation" on page 288.</li> </ul> |



| (2)           | CBnCTL1                                                                     | CBnCTL1 - CSIBn control register 1                                              |   |        |        |         |         |         |
|---------------|-----------------------------------------------------------------------------|---------------------------------------------------------------------------------|---|--------|--------|---------|---------|---------|
|               | CBnCTL1                                                                     | CBnCTL1 is an 8-bit register that controls the CSIBn serial transfer operation. |   |        |        |         |         |         |
| Access        | This regis                                                                  | This register can be read/written in 8-bit or 1-bit units.                      |   |        |        |         |         |         |
| Address       |                                                                             | CB0CTL1: FFFFFD01 <sub>H</sub><br>CB1CTL1: FFFFFD21 <sub>H</sub>                |   |        |        |         |         |         |
| Initial Value | 00 <sub>H</sub> . This register is cleared by any reset.                    |                                                                                 |   |        |        |         |         |         |
|               | 7                                                                           | 6                                                                               | 5 | 4      | 3      | 2       | 1       | 0       |
| CBnCTL1       | 0                                                                           | 0                                                                               | 0 | CBnCKP | CBnDAP | CBnCKS2 | CBnCKS1 | CBnCKS0 |
|               | R                                                                           | R                                                                               | R | R/W    | R/W    | R/W     | R/W     | R/W     |
|               |                                                                             |                                                                                 |   |        |        |         |         |         |
| Caution       | The CBnCTL1 register can be rewritten only when the CBnCTL0.CBnPWR bit = 0. |                                                                                 |   |        |        |         |         |         |

# Table 12-3 CBnCTL1 register contents (1/2)

| Bit<br>position | Bit name         | Function                                                                  |        |                                                                                                                             |  |  |  |
|-----------------|------------------|---------------------------------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 4<br>3          | CBnCKP<br>CBnDAP | Specification of data transmission/reception timing in relation to SCKBn. |        |                                                                                                                             |  |  |  |
|                 |                  | CBnCKP                                                                    | CBnDAP | SIBn/SOBn timing in relation to SCKBn                                                                                       |  |  |  |
|                 |                  | 0                                                                         | 0      | Communication type 1       SCKBn (I/O)       SOBn (output)       X D7 X D6 X D5 X D4 X D3 X D2 X D1 X D0       SIBn capture |  |  |  |
|                 |                  | 0                                                                         | 1      | Communication type 2<br>SCKBn (I/O)<br>SOBn (output)<br>SIBn capture<br>A A A A A A A A A A A A A A A A A A A               |  |  |  |
|                 |                  | 1                                                                         | 0      | Communication type 3<br>SCKBn (I/O)<br>(output)<br>SIBn capture<br>(output)<br>SIBn capture                                 |  |  |  |
|                 |                  | 1                                                                         | 1      | Communication type 4<br>SCKBn (I/O)                                                                                         |  |  |  |



| Bit<br>position | Bit name    | Function   |              |         |                        |             |
|-----------------|-------------|------------|--------------|---------|------------------------|-------------|
| 2 to 0          | CBnCKS[2:0] | Communicat | ion clock se | tting.  |                        |             |
|                 |             | CBnCKS2    | CBnCKS1      | CBnCKS0 | Communication clock    | Mode        |
|                 |             | 0          | 0            | 0       | BRG0                   | Master mode |
|                 |             | 0          | 0            | 1       | BRG1                   | Master mode |
|                 |             | 0          | 1            | 0       | PCLK2                  | Master mode |
|                 |             | 0          | 1            | 1       | PCLK3                  | Master mode |
|                 |             | 1          | 0            | 0       | PCLK4                  | Master mode |
|                 |             | 1          | 0            | 1       | PCLK5                  | Master mode |
|                 |             | 1          | 1            | 0       | PCLK6                  | Master mode |
|                 |             | 1          | 1            | 1       | External clock (SCKBn) | Slave mode  |

#### Table 12-3 CBnCTL1 register contents (2/2)

Note PCLK2 to PCLK6: peripheral clocks (refer to "Clock Generator" on page 148):

| PCLK    | 2 | 3 | 4 | 5 | 6   |
|---------|---|---|---|---|-----|
| f [MHz] | 8 | 4 | 2 | 1 | 0.5 |

Additional clocks are generated by dedicated baud rate generators BRG0/BRG1.



| (3)           | CBnCTL2                | CBnCTL2 - CSIBn control register 2                                                   |             |            |            |        |        |        |
|---------------|------------------------|--------------------------------------------------------------------------------------|-------------|------------|------------|--------|--------|--------|
|               | CBnCTL2<br>bits.       | CBnCTL2 is an 8-bit register that controls the number of CSIBn serial transfer bits. |             |            |            |        |        |        |
| Access        | This regis             | This register can be read/written in 8-bit units.                                    |             |            |            |        |        |        |
| Address       |                        | CB0CTL2: FFFFFD02 <sub>H</sub><br>CB1CTL2: FFFFFD22 <sub>H</sub>                     |             |            |            |        |        |        |
| Initial Value | 00 <sub>H</sub> . This | 00 <sub>H</sub> . This register is cleared by any reset.                             |             |            |            |        |        |        |
|               | 7                      | 6                                                                                    | 5           | 4          | 3          | 2      | 1      | 0      |
| CBnCTL2       | 0                      | 0                                                                                    | 0           | 0          | CBnCL3     | CBnCL2 | CBnCL1 | CBnCL0 |
|               | R/W                    | R/W                                                                                  | R/W         | R/W        | R/W        | R/W    | R/W    | R/W    |
|               |                        |                                                                                      |             |            |            |        |        |        |
| Caution       | The CBn                | CTL2 regis                                                                           | ster can be | e rewritte | n only whe | n the  |        |        |

CBnCTL0.CBnPWR bit = 0 or when both the CBnTXE and CBnRXE bits = 0.

| Table 12-4 | CBnCTL2 register contents |
|------------|---------------------------|

| Bit<br>position | Bit name   | Function    |                                                   |        |        |                                |  |  |  |
|-----------------|------------|-------------|---------------------------------------------------|--------|--------|--------------------------------|--|--|--|
| 3 to 0          | CBnCL[3:0] | Number of s | Number of serial transfer bits (character length) |        |        |                                |  |  |  |
|                 |            | CBnCL3      | CBnCL2                                            | CBnCL1 | CBnCL0 | Number of serial transfer bits |  |  |  |
|                 |            | 0           | 0                                                 | 0      | 0      | 8 bits                         |  |  |  |
|                 |            | 0           | 0                                                 | 0      | 1      | 9 bits                         |  |  |  |
|                 |            | 0           | 0                                                 | 1      | 0      | 10 bits                        |  |  |  |
|                 |            | 0           | 0                                                 | 1      | 1      | 11 bits                        |  |  |  |
|                 |            | 0           | 1                                                 | 0      | 0      | 12 bits                        |  |  |  |
|                 |            | 0           | 1                                                 | 0      | 1      | 13 bits                        |  |  |  |
|                 |            | 0           | 1                                                 | 1      | 0      | 14 bits                        |  |  |  |
|                 |            | 0           | 1                                                 | 1      | 1      | 15 bits                        |  |  |  |
|                 |            | 1           | х                                                 | х      | х      | 16 bits                        |  |  |  |
|                 |            |             |                                                   |        |        |                                |  |  |  |

**Note** If the number of transfer bits is other than 8 or 16, prepare and use data stuffed from the LSB of the CBnTX0 and CBnRX0 registers.

Transfer data length<br/>change functionThe CSIBn transfer data length can be set in 1-bit units between 8 and 16 bits<br/>using the CBnCTL2.CBnCL[3:0] bits.

When the transfer bit length is set to a value other than 16 bits, set the data to the CBnTX0 or CBnRX0 register starting from the LSB, regardless of whether the transfer start bit is the MSB or LSB. Any data can be set for the higher bits that are not used, but the receive data becomes 0 following serial transfer.





Figure 12-2 (i) Transfer bit length = 10 bits, MSB first



Figure 12-3 (ii) Transfer bit length = 12 bits, LSB first



| (4)           | CBnSTR - CSIBn status register                                                                                                                                             |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | CBnSTR is an 8-bit register that displays the CSIBn status.                                                                                                                |
| Access        | This register can be read/written in 8-bit or 1-bit units.<br>Bit CBnTSF is read-only.                                                                                     |
| Address       | CB0CTL2: FFFFFD03 <sub>H</sub><br>CB1CTL2: FFFFFD23 <sub>H</sub>                                                                                                           |
| Initial Value | 00 <sub>H</sub> . This register is cleared by any reset.<br>In addition to reset input, the CBnSTR register can be initialized by clearing the<br>CBnCTL0.CBnPWR bit to 0. |

|        | 7      | 6   | 5   | 4   | 3   | 2   | 1   | 0      |
|--------|--------|-----|-----|-----|-----|-----|-----|--------|
| CBnSTR | CBnTSF | 0   | 0   | 0   | 0   | 0   | 0   | CBnOVE |
|        | R      | R/W    |

#### Table 12-5 CBnSTR register contents

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7               | CBnTSF   | Communication status flag<br>0: Communication stopped<br>1: Communicating<br>During transmission, this register is set when data is prepared in the CBnTX register,<br>and during reception, it is set when a dummy read of the CBnRX register is<br>performed.<br>When transfer ends, this flag is cleared to 0 at the last edge of the clock.                                                                                                                   |
| 0               | CBnOVE   | <ul> <li>Overrun error flag <ul> <li>No overrun</li> <li>Overrun</li> </ul> </li> <li>Overrun</li> <li>An overrun error occurs when the next reception starts without performing a CPU read of the value of the receive buffer, upon completion of the receive operation. The CBnOVE flag displays the overrun error occurrence status in this case.</li> <li>The CBnOVE flag is cleared by writing 0 to it. It cannot be set even by writing 1 to it.</li> </ul> |

- **Note** In case of an overrun error, the reception error interrupt INTCBnRE behaves different, depending on the transfer mode:
  - Continuous transfer mode The reception error interrupt INTCBnRE is generated instead of the reception completion interrupt INTCBnR.
  - Single transfer mode No interrupt is generated.
  - In either case the overflow flag CBnSTR.CBnOVE is set to 1 and the previous data in CBnRX0 will be overwritten with the new data.



# 12.4 Operation

# 12.4.1 Single transfer mode (master mode, transmission/reception mode)

MSB first (CBnCTL0.CBnDIR = 0),

communication type 1 (CBnCTL1.CBnCKP = 0, CBnCTL1.CBnDAP = 0), transfer data length = 8 bits (CBnCTL2.CBnCL[3:0] = 0000B)



- 1. Clear the CBnCTL0.CBnPWR bit to 0.
- 2. Set the CBnCTL1 and CBnCTL2 registers to specify the transfer mode.
- 3. Set the CBnTXE, CBnRXE, and CBnSCE bits of the CBnCTL0 register to 1 at the same time as specifying the transfer mode using the CBnDIR bit, to set the transmission/reception enabled status.
- 4. Set the CBnPWR bit to 1 to enable the CSIBn operation.
- 5. Write transfer data to the CBnTX0 register (transmission/reception start).
- 6. The reception complete interrupt request signal (INTCBnR) is output.
- 7. Read the CBnRX0 register before clearing the CBnPWR bit to 0.
- 8. Check that the CBnSTR.CBnTSF bit = 0 and set the CBnPWR bit to 0 to stop operation of CSIBn (end of transmission/reception).

To continue transfer, repeat steps (5) to (7) before (8).



| Note    | <ol> <li>In transmission mode or transmission/reception mode, communication is<br/>not started by reading the CBnRX0 register.</li> </ol>                                                                                                                                                                                   |  |  |  |  |  |  |  |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
|         | 2. In single transmission or single transmission/reception mode, the INTCBnT signal is not generated. When communication is complete, the INTCBnR signal is generated.                                                                                                                                                      |  |  |  |  |  |  |  |
|         | 3. The processing of steps (3) and (4) can be set simultaneously.                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |
|         |                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
|         |                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
| Caution | In case the CSIB interface is operating in                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |
|         | <ul> <li>single transmit/reception mode (CBnCTL0.CBnTMS = 0)</li> </ul>                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |
|         | <ul> <li>communication type 2 respectively type 4 (CBnCTL1.CBnDAP = 1)</li> </ul>                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |
|         | pay attention to following effect:                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
|         | In case the next transmit should be initiated immediately after the occurrence of the reception completion interrupt INTCBnR any write to the CBnTX0 register is ignored as long as the communication status flag is still reflecting an ongoing communication (CBnTSF = 1). Thus the new transmission will not be started. |  |  |  |  |  |  |  |
|         | For trasmitting data continuously use one of the following options:                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |
|         | <ul> <li>Use continuous transfer mode (CBnCTL0.CBnTMS = 1). This is the only usable mode for automatic transmission of data by the DMA Controller.</li> </ul>                                                                                                                                                               |  |  |  |  |  |  |  |

 If single transfer mode (CBnCTL0.CBnTMS = 0) should be used, CBnSTR.CBnTSF = 0 needs to be verified before writing data to the CBnTX0 register.



## 12.4.2 Single transfer mode (master mode, reception mode)

MSB first (CBnCTL0.CBnDIR = 0), communication type 1 (CBnCTL1.CBnCKP = 0, CBnCTL1.CBnDAP = 0), transfer data length = 8 bits (CBnCTL2.CBnCL[3:0] = 0000B)



- 1. Clear the CBnCTL0.CBnPWR bit to 0.
- 2. Set the CBnCTL1 and CBnCTL2 registers to specify the transfer mode.
- 3. Set the CBnCTL0.CBnRXE and CBnCTL0.CBnSCE bits to 1, CBnCTL0.TXE to 0, at the same time as specifying the transfer mode using the CBnDIR bit, to set the reception enabled status.
- 4. Set the CBnPWR bit to 1 to enable the CSIBn operation.
- 5. Perform a dummy read of the CBnRX0 register (reception start trigger).
- 6. The reception complete interrupt request signal (INTCBnR) is output.
- 7. Set the CBnSCE bit to 0 to set the final receive data status.
- 8. Read the CBnRX0 register.
- 9. Check that the CBnSTR.CBnTSF bit = 0 and set the CBnPWR bit to 0 to stop the CSIBn operation (end of reception).

To continue transfer, repeat steps (5) and (6) before (7). (At this time, (5) is not a dummy read, but a receive data read combined with the reception trigger.)

Note The processing of steps (3) and (4) can be set simultaneously.



# 12.4.3 Continuous mode (master mode, transmission/reception mode)

MSB first (CBnCTL0.CBnDIR = 0), communication type 3 (CBnCTL1.CBnCKP = 1, CBnCTL1.CBnDAP = 0), transfer data length = 8 bits (CBnCTL2.CBnCL[3:0] = 0000B)



- 1. Clear the CBnCTL0.CBnPWR bit to 0.
- 2. Set the CBnCTL1 and CBnCTL2 registers to specify the transfer mode.
- 3. Set the CBnTXE, CBnRXE, and CBnSCE bits of the CBnCTL0 register to 1 at the same time as specifying the transfer mode using the CBnDIR bit, to set the transmission/reception enabled status.
- 4. Set the CBnPWR bit to 1 to enable the CSIBn operation.
- 5. Write transfer data to the CBnTX0 register (transmission/reception start).
- 6. The transmission enable interrupt request signal (INTCBnT) is received and transfer data is written to the CBnTX0 register.
- The reception complete interrupt request signal (INTCBnR) is output. Read the CBnRX0 register before the next receive data arrives or before the CBnPWR bit is cleared to 0.
- 8. Check that the CBnSTR.CBnTSF bit = 0 and set the CBnPWR bit to 0 to stop the operation of CSIBn (end of transmission/reception).



To continue transfer, repeat steps (5) to (7) before (8).

In transmission mode or transmission/reception mode, the communication is not started by reading the CBnRX0 register.



### 12.4.4 Continuous mode (master mode, reception mode)

MSB first (CBnCTL0.CBnDIR = 0), communication type 2 (CBnCTL1.CBnCKP = 0, CBnCTL1.CBnDAP = 1), transfer data length = 8 bits (CBnCTL2.CBnCL[3:0] = 0000B)



- 1. Clear the CBnCTL0.CBnPWR bit to 0.
- 2. Set the CBnCTL1 and CBnCTL2 registers to specify the transfer mode.
- 3. Set the CBnCTL0.CBnRXE and CBnCTL0.CBnSCE bits to 1 at the same time as specifying the transfer mode using the CBnDIR bit, to set the reception enabled status.
- 4. Set the CBnPWR bit to 1 to enable the CSIBn operation.
- 5. Perform a dummy read of the CBnRX0 register (reception start trigger).
- The reception complete interrupt request signal (INTCBnR) is output. Read the CBnRX0 register before the next receive data arrives or before the CBnPWR bit is cleared to 0.
- 7. Set the CBnCTL0.CBnSCE bit = 0 while the last data being received to set the final receive data status.
- 8. Check that the CBnSTR.CBnTSF bit = 0 and set the CBnPWR bit to 0 to stop the operation of CSIBn (end of reception).

To continue transfer, repeat steps (5) and (6) before (7).



## 12.4.5 Continuous reception mode (error)

MSB first (CBnCTL0.CBnDIR = 0), communication type 2 (CBnCTL1.CBnCKP = 0, CBnCTL1.CBnDAP = 1), transfer data length = 8 bits (CBnCTL2.CBnCL[3:0] = 0000B)



- 1. Clear the CBnCTL0.CBnPWR bit to 0.
- 2. Set the CBnCTL1 and CBnCTL2 registers to specify the transfer mode.
- 3. Set the CBnCTL0.CBnRXE and CBnCTL0.CBnSCE bits to 1 at the same time as specifying the transfer mode using the CBnDIR bit, to set the reception enabled status.
- 4. Set the CBnPWR bit = 1 to enable CSIBn operation.
- 5. Perform a dummy read of the CBnRX0 register (reception start trigger).
- 6. The reception complete interrupt request signal (INTCBnR) is output.
- 7. If the data could not be read before the end of the next transfer, the CBnSTR.CBnOVE flag is set to 1 upon the end of reception and the INTCBnR signal is output.
- 8. Overrun error processing is performed after checking that the CBnOVE bit = 1 in the INTCBnRE interrupt servicing.
- 9. Clear CBnOVE bit to 0.
- 10. Check that the CBnSTR.CBnTSF bit = 0 and set the CBnPWR bit to 0 to stop the operation CSIBn (end of reception).



# 12.4.6 Continuous mode (slave mode, transmission/reception mode)

MSB first (CBnCTL0.CBnDIR = 0), communication type 2 (CBnCTL1.CBnCKP = 0, CBnCTL1.CBnDAP = 1), transfer data length = 8 bits (CBnCTL2.CBnCL[3:0] = 0000B)



- 1. Clear the CBnCTL0.CBnPWR bit to 0.
- 2. Set the CBnCTL1 and CBnCTL2 registers to specify the transfer mode.
- 3. Set the CBnTXE, CBnRXE and CBnSCE bits of the CBnCTL0 register to 1 at the same time as specifying the transfer mode using the CBnDIR bit, to set the transmission/reception enabled status.
- 4. Set the CBnPWR bit to 1 to enable supply of the CSIBn operation.
- 5. Write the transfer data to the CBnTX0 register.
- 6. The transmission enable interrupt request signal (INTCBnT) is received and the transfer data is written to the CBnTX0 register.
- 7. The reception complete interrupt request signal (INTCBnR) is output. Read the CBnRX0 register.
- 8. Check that the CBnSTR.CBnTSF bit = 0 and set the CBnPWR bit to 0 to stop the operation of CSIBn (end of transmission/reception).

RENESAS

#### To continue transfer, repeat steps (5) to (7) before (8).

**Discontinued transmission** In case the CSIB is operating in continuous slave transmission mode (CBnCTL0.CBnTMS = 1, CBnCTL1.CBnCKS[2:0] =  $111_B$ ) and new data is not written to the CBnTX0 register the SOBn pin outputs the level of the last bit.



Figure 12-4 outlines this behaviour.



The example shows the situation that two data bytes (55<sub>H</sub>, AA<sub>H</sub>) are transmitted correctly, but the third (96<sub>H</sub>) fails.

- (1) Data  $55_{\text{H}}$  is written (by the CPU or DMA) to CBnTX0.
- (2) The master issues the clock SCKBn and transmission of  $55_{\rm H}$  starts.
- (3) INTCBnT is generated and the next data AA<sub>H</sub> is written to CBnTX0 promptly, i.e. before the first data has been transmitted completely.
- (4) Transmission of the second data AA<sub>H</sub> continues correctly and INTCBnT is generated. But this time the next data is not written to CBnTX0 in time.
- (5) Since there is no new data available in CBnTX0, but the master continuous to apply SCKBn clocks, SOBn remains at the level of the transmitted last bit.
- (6) New data (96<sub>H</sub>) is written to CBnTX0.
- (7) With the next SCKBn cycle transmission of the new data  $(96_H)$  starts.

As a consequence the master receives a corrupted data byte from (5) onwards, which is made up of a random number of the repeated last bit of the former data and some first bits of the new data.



## 12.4.7 Continuous mode (slave mode, reception mode)

MSB first (CBnCTL0.CBnDIR bit = 0), communication type 1 (CBnCTL1.CBnCKP = 0, CBnCTL1.CBnDAP = 0), transfer data length = 8 bits (CBnCTL2.CBnCL[3:0] = 0000B)



- 1. Clear the CBnCTL0.CBnPWR bit to 0.
- 2. Set the CBnCTL1 and CBnCTL2 registers to specify the transfer mode.
- 3. Set the CBnCTL0.CBnRXE and CBnCTL0.CBnSCE bits to 1 at the same time as specifying the transfer mode using the CBnDIR bit, to set the reception enabled status.
- 4. Set the CBnPWR bit = 1 to enable CSIBn operation.
- 5. Perform a dummy read of the CBnRX0 register (reception start trigger).
- 6. The reception complete interrupt request signal (INTCBnR) is output. Read the CBnRX0 register.
- 7. Check that the CBnSTR.CBnTSF bit = 0 and set the CBnPWR bit to 0 to stop the operation of CSIBn (end of reception).

To continue transfer, repeat steps (5) and (6) before (7).







Figure 12-5 (i) Communication type 1 (CBnCKP = 0, CBnDAP = 0)







Figure 12-7 (iii) Communication type 2 (CBnCKP = 0, CBnDAP = 1)







- Note 1. The INTCBnT interrupt is set when the data written to the transmit buffer is transferred to the data shift register in the continuous transmission or continuous transmission/reception modes. In the single transmission or single transmission/reception modes, the INTCBnT interrupt request signal is not generated, but the INTCBnR interrupt request signal is generated upon completion of communication.
  - 2. The INTCBnR interrupt occurs if reception is correctly completed and receive data is ready in the CBnRX0 register while reception is enabled, and if an overrun error occurs. In the single mode, the INTCBnR interrupt request signal is generated even in the transmission mode, upon completion of communication.



# 12.5 Output Pins

#### (1) SCKBn pin

When CSIBn operation is disabled (CBnCTL0.CBnPWR bit = 0), the SCKBn pin output status is as follows.

| CBnCKP | CBnCKS2    | CBnCKS1         | CBnCKS0    | SCKBn pin output    |
|--------|------------|-----------------|------------|---------------------|
| 0      | Don't care | Don't care      | Don't care | Fixed to high level |
| 1      | 1          | 1               | 1          | High impedance      |
|        | C          | Other than abov | e          | Fixed to low level  |

**Note** The output level of the SCKBn pin changes if any of the CBnCTL1.CBnCKP and CBnCKS2 to CBnCKS0 bits is rewritten.

#### (2) SOBn pin

When CSIBn operation is disabled (CBnPWR bit = 0), the SOBn pin output status is as follows.

| CBnTXE | CBnDAP | CBnDIR | SOBn pin output              |
|--------|--------|--------|------------------------------|
| 0      | ×      | ×      | Fixed to low level           |
| 1      | 0      | ×      | SOBn latch value (low level) |
|        | 1      | 0      | CBnTX0 value (MSB)           |
|        |        | 1      | CBnTX0 value (LSB)           |

- **Note 1.** The SOBn pin output changes when any one of the CBnCTL0.CBnTXE, CBnCTL0.CBnDIR bits, and CBnCTL1.CBnDAP bit is rewritten.
  - 2. ×: don't care



# 12.6 Operation Flow

#### (1) Single transmission



Note Set the CBnSCE bit to 1 in the initial setting.

**Caution** In the slave mode, data cannot be correctly transmitted if the next transfer clock is input earlier than the CBnTX0 register is written.



#### (2) Single reception



Note Set the CBnSCE bit to 1 in the initial setting.

**Caution** In the single mode, data cannot be correctly received if the next transfer clock is input earlier than the CBnRX0 register is read.







- Note 1. Set the CBnSCE bit to 1 in the initial setting.
  - 2. If the next transfer is reception only, dummy data is written to the CBnTX0 register.
- **Caution** Even in the single mode, the CBnSTR.CBnOVE flag is set to 1. If only transmission is used in the transmission/reception mode, therefore, programming without checking the CBnOVE flag is recommended.







Note Set the CBnSCE bit to 1 in the initial setting.



#### (5) Continuous reception



Note Set the CBnSCE bit to 1 in the initial setting.

Caution In the master mode, the clock is output without limit when dummy data is read from the CBnRX0 register. To stop the clock, execute the flow marked ◆ in the above flowchart.
 In the slave mode, malfunction due to noise during communication can be prevented by executing the flow marked ◆ in the above flowchart.
 Before resuming communication, set the CBnCTL0.CBnSCE bit to 1, and read dummy data from the CBnRX0 register.

RENESAS

#### (6) Continuous transmission/reception



Note Set the CBnSCE bit to 1 in the initial setting.



# 12.7 Baud Rate Generator

# 12.7.1 Overview

Each CSIBn interface is equipped with a dedicated baud rate generator.



Figure 12-9 Block diagram of baudrate generator (BRGm)

The baud rate generators 0 and 1 (BRG0, BRG1) and CSIB0 and CSIB1 are connected as shown in the following block diagram.



- Figure 12-10 Connection between CSIBn and baud rate generators
  - **Note** An unused baud rate generator (BRGm) can be employed as interval timer generating a dedicated interrupt request (INTBRGm).



## 12.7.2 Baud rate generator registers

#### (1) Prescaler mode registers (PRSMm)

The PRSMm register controls generation of the baud rate signal for CSIB.

Access This register can be read/written in 8-bit or 1-bit units.

Address PRSM0: FFFFFDC0<sub>H</sub> PRSM1: FFFFFDD0<sub>H</sub>

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|       | 7 | 6 | 5 | 4     | 3   | 2      | 1      | 0      |
|-------|---|---|---|-------|-----|--------|--------|--------|
| PRSMm | 0 | 0 | 0 | BGCEm | 0   | TODISm | BGCSm1 | BGCSm0 |
|       | R | R | R | R/W   | R/W | R/W    | R/W    | R/W    |

Caution 1. Do not rewrite the PRSMm register during operation.

2. Set bits BGCSm0, BGCSm1 and TODISm before setting the BGCEn bit to 1.

#### Table 12-6PRSMm register contents

| Bit<br>position | Bit name        | Function                                |             |                     |                              |                   |
|-----------------|-----------------|-----------------------------------------|-------------|---------------------|------------------------------|-------------------|
| 4<br>2          | BGCEm<br>TODISm | Specification                           | of baudrate | e generator output. |                              |                   |
|                 |                 | BGCEm                                   | TODISm      | BRGOUT              | INTBRG                       | Counter           |
|                 |                 | 0                                       | 0           | Fixed to 0          | Fixed to 0                   | Fixed to 01H      |
|                 |                 | 0                                       | 1           | Fixed to 0          | Fixed to 0                   | Fixed to 01H      |
|                 |                 | 1                                       | 0           | Active              | Active                       | Active            |
|                 |                 | 1                                       | 1           | Fixed to 0          | Active                       | Active            |
| 1, 0            | BGCSm[1:0]      | Baudrate generator input clock setting. |             |                     |                              |                   |
|                 |                 | BGCSm1                                  | BGCSm0      | Input clock sel     | ection (f <sub>BGCSm</sub> ) | Setting value (k) |
|                 |                 | 0                                       | 0           | PCLK1 (16 Mhz)      |                              | 0                 |
|                 |                 | 0                                       | 1           | PCLK1 :2 (8 Mhz)    |                              | 1                 |
|                 |                 | 1                                       | 0           | PCLK1 :4 (4 Mhz)    |                              | 2                 |
|                 |                 | 1                                       | 1           | PCLK1 :8 (2Mhz)     |                              | 3                 |



| (2)           | Prescaler compare registers (PRSCMm)<br>The PRSCMm registers are 8-bit compare registers. |             |             |             |          |         |         |         |
|---------------|-------------------------------------------------------------------------------------------|-------------|-------------|-------------|----------|---------|---------|---------|
| Access        | This regis                                                                                | ter can be  | e read/writ | ten in 8-bi | t units. |         |         |         |
| Address       | PRSCM0: FFFFFDC0 <sub>H</sub><br>PRSCM1: FFFFFDD0 <sub>H</sub>                            |             |             |             |          |         |         |         |
| Initial Value | 00 <sub>H</sub> . This                                                                    | register is | cleared b   | by any res  | et.      |         |         |         |
|               | 7                                                                                         | 6           | 5           | 4           | 3        | 2       | 1       | 0       |
| PRSCMm        | PRSCMm7                                                                                   | PRSCMm6     | PRSCMm5     | PRSCMm4     | PRSCMm3  | PRSCMm2 | PRSCMm1 | PRSCMm0 |
|               | R/W                                                                                       | R/W         | R/W         | R/W         | R/W      | R/W     | R/W     | R/W     |
|               |                                                                                           |             |             |             |          |         |         |         |
| Caution       | 1. Do not rewrite the PRSCMm register during operation.                                   |             |             |             |          |         |         |         |

2. Set the PRSCMm register before setting the PRSMm.BGCEn bit to 1.

#### Table 12-7 PRSMm register contents

| Bit<br>position | Bit name    | Function                                      |
|-----------------|-------------|-----------------------------------------------|
| 7 to 0          | PRSCMm[7:0] | Specification of prescaler compare value (N). |
|                 |             | <b>Note:</b> If PRSCMm[7:0] = 0, then N = 256 |



# 12.7.3 Baud rate generation

The transmission/reception clock is generated by dividing the main clock. The baud rate generated from the main clock is obtained by the following equation.

$$f_{BRGn} = \frac{PCLK1}{2^{k} \times N \times 2}$$

| <b>f</b> BRGn: | BRGm output clock                                                |
|----------------|------------------------------------------------------------------|
| PCLK1:         | 16 MHz peripheral clock (refer to "Clock Generator" on page 148) |
| k:             | PRSMm.BGCSm[1:0] register setting value ( $0 \le k \le 3$ )      |
| N:             | PRSCMm.PRSCMn[7:0] register value<br>if PRSCMm = 00H: N = 256    |



# 12.8 Cautions

## 12.8.1 CSIB operation stop

**Description** If any channel of CSIBn is operated in slave mode and an external clock signal is input via the SCKBn pin while no transmission or reception sequence is in progress the CSIB may stop operating.

Depending on the CSIB operating configuration the CSIB behaves as described below.

 Transmit mode or transmit/receive mode: In transmit mode (CBnCTL0.CBnTXE = 1, CBnCTL0.CBnRXE = 0) or transmit/receive mode (CBnCTL0.CBnTXE = 1, CBnCTL0.CBnRXE = 1) a write operation to the CBnTX0 register may trigger the aforementioned behaviour.

Any write to the related CBnTX0 register will no longer start a transmission sequence. Furthermore the related transmission interrupt request will not be generated.

 Receive mode: In receive mode (CBnCTL0.CBnTXE = 0, CBnCTL0.CBnRXE = 1) a read operation from the CBnRX0 register may trigger the aforementioned behaviour.

Any read from the related CBnRX0 register will no longer start a receive sequence. Furthermore the related receive interrupt request will not be generated.

The described CSIBn stop condition can be escaped by initiating a system reset or by a sequential clear and set of the CBnCTL0.CBnPWR bit.

- **Workaround** In order to avoid the CSIBn stop condition in slave mode take the following precautions.
  - Transmit mode or transmit/receive mode: Make sure the external clock via the SCKBn pin is not input while writing to the CBnTX0 register after a transmission sequence is finished.
  - Receive mode: Make sure the external clock via the SCKBn pin is not input While reading from the CBnRX0 register after a reception sequence is finished.



# Chapter 13 Enhanced Queued Clocked Serial Interface (CSIE)

This microcontroller has two instances of the Enhanced Queued Clocked Serial Interface CSIE: CSIE0 and CSIE1.

Note Throughout this chapter, the individual instances of CSIE are identified by "n" (n = 0 to 1), for example CEnCTL2 for the Queued CSIn control register 2.

The individual chip select signals are identified by "m" (m = 0 to 7 for CSIE0 and m = 0 to 3 for CSIE1), for example SCSE06 for the chip select pin 6 of CSIE0.

# 13.1 Features

- 3-wire serial synchronous transfers
- The following pins are provided to enable a 3-wire serial interface:

| Pin Function       | CSIE0            | CSIE1            |
|--------------------|------------------|------------------|
| Serial data output | SOE0             | SOE1             |
| Serial data input  | SIE0             | SIE1             |
| Serial clock I/O   | SCKE0            | SCKE1            |
| Chip select        | SCSE00 to SCSE07 | SCSE10 to SCSE13 |

- Master mode and slave mode selectable
- Serial clock and data phase selectable
- Transfer date length selectable from 8 to 16 bits in 1-bit units
- · Data transfer with MSB- for LSB-first selectable
- Three selectable transfer modes:
  - transmit only mode
  - receive only mode
  - transmit/receive mode
- Transmit and receive FIFO (16 elements)
- · Selection between single transfer mode and block transfer mode
- Internal baud rate generator
- · Programmable baud rate through BRG output (master) or slave clock
- DMA transfer of received data to memory available
- Maximum SCKE frequency: 8 MHz
- **Note** In all figures of this chapter, except where explicitly mentioned, it is assumed that the chip select signals SCSEn0 to SCSEn7 are set as "active low", although it is possible to define the active level for each chip select also to "active high".

RENESAS







Note 1. CSIE1 offers only four chip select pins: SCSE10 to SCSE13.

2.  $f_{QCSI} = f_{PCLK0} = 32$  MHz is the clock supply of the Queued-CSI macro.



## 13.1.2 Input/Output pins

The table below shows the input/output pins of the CSIE.

#### Table 13-1 Input/Output Pins of the CSIE

| Signal<br>name      | I/O | Active<br>level | Disabled<br>level | Function                               |
|---------------------|-----|-----------------|-------------------|----------------------------------------|
| SCKEn               | I/O | _               | Н                 | Serial clock signal                    |
| SIEn                | I   | _               | _                 | Input serial data signal               |
| SOEn                | 0   | _               | _                 | Output serial data signal              |
| SCSEn0              | 0   | L <sup>a</sup>  | H <sup>a</sup>    | Serial peripheral chip select signal 0 |
| SCSEn1              | 0   | La              | H <sup>a</sup>    | Serial peripheral chip select signal 1 |
| SCSEn2              | 0   | L <sup>a</sup>  | H <sup>a</sup>    | Serial peripheral chip select signal 2 |
| SCSEn3              | 0   | L <sup>a</sup>  | H <sup>a</sup>    | Serial peripheral chip select signal 3 |
| SCSEn4 <sup>b</sup> | 0   | L <sup>a</sup>  | H <sup>a</sup>    | Serial peripheral chip select signal 4 |
| SCSEn5 <sup>b</sup> | 0   | L <sup>a</sup>  | H <sup>a</sup>    | Serial peripheral chip select signal 5 |
| SCSEn6 <sup>b</sup> | 0   | L <sup>a</sup>  | H <sup>a</sup>    | Serial peripheral chip select signal 6 |
| SCSEn7 <sup>b</sup> | 0   | La              | H <sup>a</sup>    | Serial peripheral chip select signal 7 |

a) The active level is programmable for each chip select. b)

Not available for CSIE1.



# 13.2 Queued CSI Control Registers

The Enhanced Queued CSIEs are controlled and operated by means of the following registers:

#### Table 13-2 CSIEn register overview

| Register name                      | Shortcut | Address                   |
|------------------------------------|----------|---------------------------|
| Queued CSI control register 0      | CEnCTL0  | <base/>                   |
| Queued CSI control register 1      | CEnCTL1  | <base/> + 01 <sub>H</sub> |
| Receive data buffer                | CEnRX0   | <base/> + 02 <sub>H</sub> |
| Chip Select FIFO buffer            | CEnCS    | <base/> + 04 <sub>H</sub> |
| Transmit data FIFO buffer          | CEnTX0   | <base/> + 06 <sub>H</sub> |
| CSI Buffer Status Register         | CEnSTR   | <base/> + 08 <sub>H</sub> |
| Queued CSI control register 2      | CEnCTL2  | <base/> + 09 <sub>H</sub> |
| Queued CSI control register 3      | CEnCTL3  | <base/> + 0C <sub>H</sub> |
| Queued CSI control register 4      | CEnCTL4  | <base/> + 0D <sub>H</sub> |
| CSEn0 enhanced timing              | CEnOPT0  | <base/> + 10 <sub>H</sub> |
| CSEn1 enhanced timing              | CEnOPT1  | <base/> + 12 <sub>H</sub> |
| CSEn2 enhanced timing              | CEnOPT2  | <base/> + 14 <sub>H</sub> |
| CSEn3 enhanced timing              | CEnOPT3  | <base/> + 16 <sub>H</sub> |
| CSEn4 enhanced timing <sup>a</sup> | CEnOPT4  | <base/> + 18 <sub>H</sub> |
| CSEn5 enhanced timing <sup>a</sup> | CEnOPT5  | <base/> + 1A <sub>H</sub> |
| CSEn6 enhanced timing <sup>a</sup> | CEnOPT6  | <base/> + 1C <sub>H</sub> |
| CSEn7 enhanced timing <sup>a</sup> | CEnOPT7  | <base/> + 1E <sub>H</sub> |

a) only valid for CSIE0

#### Table 13-3 CSIEn register base address

| CSIE module | Base address           |
|-------------|------------------------|
| CSIE0       | FFFF FD40 <sub>H</sub> |
| CSIE1       | FFFF FD80 <sub>H</sub> |



| (1)           | <b>CEnCTL0 - Queued CSI control register 0</b><br>The CEnCTL0 register controls the Queued CSI macro's operations. |                                                                                                                                                                                                                                                                                                   |             |             |              |        |       |        |  |
|---------------|--------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------|--------------|--------|-------|--------|--|
| Access        | This regis                                                                                                         | ter can be                                                                                                                                                                                                                                                                                        | e read/writ | ten in 8-bi | t or 1-bit u | inits. |       |        |  |
| Address       |                                                                                                                    | CE0CTL0: FFFFFD40 <sub>H</sub><br>CE1CTL0: FFFFFD80 <sub>H</sub>                                                                                                                                                                                                                                  |             |             |              |        |       |        |  |
| Initial Value | 00 <sub>H</sub> . This                                                                                             | 00 <sub>H</sub> . This register is cleared by any reset.                                                                                                                                                                                                                                          |             |             |              |        |       |        |  |
|               | 7                                                                                                                  | 6                                                                                                                                                                                                                                                                                                 | 5           | 4           | 3            | 2      | 1     | 0      |  |
| CEnCTL0       | CEnPWR                                                                                                             | CEnTXE                                                                                                                                                                                                                                                                                            | CEnRXE      | CEnTMS      | CEnDIR       | CEnSIT | CEnWE | CEnCSM |  |
|               | R/W                                                                                                                | R/W                                                                                                                                                                                                                                                                                               | R/W         | R/W         | R/W          | R/W    | R/W   | R/W    |  |
|               |                                                                                                                    |                                                                                                                                                                                                                                                                                                   |             |             |              |        |       |        |  |
| Caution       | time.<br>While C<br>CEnTX                                                                                          | <ol> <li>When changing the CEnPWR bit, do not change any other bit at the same<br/>time.</li> <li>While CEnPWR="0", the only registers that can be accessed are CEnCTL0,<br/>CEnTX0, CEnTX0L, and CEnSTR.</li> <li>Set the CEnPWR bit before writing any of the other bits of CEnCTL0.</li> </ol> |             |             |              |        |       |        |  |

2. Write of the CEnTMS, CEnDIR, CEnSIT, CEnWE, and CEnCSM bit is only permitted when CEnTXE = 0 and CEnRXE = 0.

| Table 13-4 CEnCTL0 register conte | ents (1/2) |
|-----------------------------------|------------|
|-----------------------------------|------------|

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                            |
|-----------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7               | CEnPWR   | CSIEn operation disable/enable:<br>0: Stop CSIEn operation clock (reset internal control circuits)<br>1: Enable CSIBn operation                                                                                                                                                                     |
|                 |          | <b>Note:</b> To abort reception/transmission forcibly, clear the CEnPWR bit (not the CEnTXE bit or CEnRXE bit) to 0. The clock output stops at this time.                                                                                                                                           |
| 6               | CEnTXE   | Transmission operation disable/enable:<br>0: Disable transmission operation<br>1: Enable transmission operation<br>The SOEn output is low level and transmission is disabled when the CEnTXE bit is 0.                                                                                              |
| 5               | CEnRXE   | Receive operation disable/enable:<br>0: Disable receive operation<br>1: Enable receive operation                                                                                                                                                                                                    |
| 4               | CEnTMS   | Transfer mode select:<br>0: Single transfer mode<br>1: Block transfer mode                                                                                                                                                                                                                          |
| 3               | CEnDIR   | <ul> <li>Serial data direction selection:</li> <li>0: Data is sent/received with MSB first</li> <li>1: Data is sent/received with LSB first</li> <li>Refer to <i>"Serial data direction select function" on page 336</i> for further details on the CEnDIR bit setting.</li> </ul>                  |
| 2               | CEnSIT   | Interrupt delay mode select (INTCEnC signal):<br>0: No delay<br>1: Half clock delay<br>Refer to <i>"Additional timing and delay selections" on page 343</i> for further details on the<br>CEnSIT bit setting.<br>Note: This bit is only valid in master mode. In slave mode, no delay is generated. |



| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1               | CEnWE    | <ul> <li>Transmission wait enable/disable selection:</li> <li>0: Transmission wait disable. Not insert half clock wait at transmission start.</li> <li>1: Transmission wait enable. Insert 1 clock (SCKE) wait at transmission start.</li> <li>Refer to <i>"Additional timing and delay selections" on page 343</i> for further details on the CEnWE bit setting.</li> <li>Note: 1. This bit is only valid in master mode. In slave mode, no wait is generated.</li> </ul>                                                                                                                                                                    |
|                 |          | <ol><li>This bit has no effect when CEnCTL4.CEnOPE = 1.</li></ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0               | CEnCSM   | <ul> <li>Chip select mode specification:</li> <li>0: Chip select inactive level output disable. Do not force chip select inactive state after each transfer of a data element.</li> <li>1: Chip select inactive level output enable. Hold all chip selects inactive for half-length SCKE after each transfer of a data element.</li> <li>Refer to <i>"Additional timing and delay selections" on page 343</i> for further details on the CEnCSM bit setting.</li> <li>Note: 1. This bit is only valid for CEnWE=1.</li> <li>2. This bit is only valid in master mode. In slave mode, CS signals are always held at inactive level.</li> </ul> |
|                 |          | <b>3.</b> This bit has no effect when CEnCTL4.CEnOPE = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| Table 13-4 | CEnCTL0 register contents (2/2) |
|------------|---------------------------------|
|            |                                 |

#### Table 13-5 Combination of CEnWE and CEnCSM Bits

| CEnWE | CEnCSM | Transmission<br>wait          | Chip Select inactive level                                                   |  |  |  |
|-------|--------|-------------------------------|------------------------------------------------------------------------------|--|--|--|
| 0     | 0      | None                          | Not output                                                                   |  |  |  |
| 0     | 1      | None                          | Not output                                                                   |  |  |  |
| 1     | 0      | One SCKE<br>length clock wait | Not output                                                                   |  |  |  |
| 1     | 1      | One SCKE<br>length clock wait | Output inactive level of half-length SCKE at first half of transmission wait |  |  |  |

See *"Additional timing and delay selections" on page 343* for further details on the timing selections by CEnSIT, CEnWE, CEnCSM bits.



| (2)           | <b>CEnCTL1 - Queued CSI control register 1</b><br>The CEnCTL1 register is an 8-bit register that is used to control the serial transfer operations. |                                                                  |              |             |            |         |         |         |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|--------------|-------------|------------|---------|---------|---------|
|               | It can be r                                                                                                                                         | read or wr                                                       | itten in 1-t | oit and 8-b | oit units. |         |         |         |
|               | Initial valu                                                                                                                                        | e is 07H b                                                       | oy reset.    |             |            |         |         |         |
| Access        | This regis                                                                                                                                          | This register can be read/written in 8-bit or 1-bit units.       |              |             |            |         |         |         |
| Address       |                                                                                                                                                     | CE0CTL1: FFFFFD41 <sub>H</sub><br>CE1CTL1: FFFFFD81 <sub>H</sub> |              |             |            |         |         |         |
| Initial Value | 07 <sub>Н</sub> . Т                                                                                                                                 |                                                                  |              |             |            |         |         |         |
|               | 7                                                                                                                                                   | 6                                                                | 5            | 4           | 3          | 2       | 1       | 0       |
| CEnCTL1       | CEnMDL2                                                                                                                                             | CEnMDL1                                                          | CEnMDL0      | CEnCKP      | CEnDAP     | CEnCKS2 | CEnCKS1 | CEnCKS0 |
|               | R/W                                                                                                                                                 | R/W                                                              | R/W          | R/W         | R/W        | R/W     | R/W     | R/W     |
|               |                                                                                                                                                     |                                                                  |              |             |            |         |         |         |

Caution Write to the CEnCTL1 register is permitted only while CEnTXE = 0 and CEnRXE = 0.

| Table 13-6 | CBnCTL1 | register | contents (1/2) |
|------------|---------|----------|----------------|
|------------|---------|----------|----------------|

| Bit<br>position | Bit name | Function     |                                                     |         |                                              |             |   |  |  |
|-----------------|----------|--------------|-----------------------------------------------------|---------|----------------------------------------------|-------------|---|--|--|
| 7 to 5          | CEnMDL   | These bits a | These bits are used to modulate the selected clock. |         |                                              |             |   |  |  |
|                 | [2:0]    | CEnMDL2      | CEnMDL1                                             | CEnMDL0 | Prescaler output<br>(PRSOUT)                 | Mode        | к |  |  |
|                 |          | 0            | 0                                                   | 0       | fqcsi                                        | Master Mode | 0 |  |  |
|                 |          | 0            | 0                                                   | 1       | f <sub>QCSI</sub> /2                         | Master Mode | 1 |  |  |
|                 |          | 0            | 1                                                   | 0       | f <sub>QCSI</sub> /4                         | Master Mode | 2 |  |  |
|                 |          | 0            | 1                                                   | 1       | f <sub>QCSI</sub> /8                         | Master Mode | 3 |  |  |
|                 |          | 1            | 0                                                   | 0       | f <sub>QCSI</sub> /16                        | Master Mode | 4 |  |  |
|                 |          | 1            | 0                                                   | 1       | f <sub>QCSI</sub> /32                        | Master Mode | 5 |  |  |
|                 |          | 1            | 1                                                   | 0       | f <sub>QCSI</sub> /64                        | Master Mode | 6 |  |  |
|                 |          | 1            | 1                                                   | 1       | SCKE (input) <sup>a</sup>                    | Slave Mode  | - |  |  |
|                 |          |              |                                                     |         | mode for serial transfer<br>ueued-CSI macro. | clock.      |   |  |  |



| Bit<br>position | Bit name    | Function      |                                                                           |                                                                 |                    |               |                              |  |  |
|-----------------|-------------|---------------|---------------------------------------------------------------------------|-----------------------------------------------------------------|--------------------|---------------|------------------------------|--|--|
| 4               | CEnCKP      | Specification | Specification of data transmission/reception timing in relation to SCKEn. |                                                                 |                    |               |                              |  |  |
| 3               | CEnDAP      | CEnCKP        | CEnDAP                                                                    | P SIEn/SOEn timing in relation to SCKEn                         |                    |               |                              |  |  |
|                 |             | 0             | 0                                                                         | Communication<br>SCKBn (I/O)<br>SOBn (output)<br>SIBn capture   |                    | <br>D4 )<br>↑ | <br>                         |  |  |
|                 |             | 0             | 1                                                                         | Communication type 2<br>SCKBn (I/O)<br>SOBn (output)            |                    |               |                              |  |  |
|                 |             | 1             | 0                                                                         | Communication type 3<br>SCKBn (I/O)                             |                    |               |                              |  |  |
|                 |             | 1             | 1                                                                         | Communication type 4<br>SCKBn (I/O)<br>(output)<br>SIBn capture |                    |               |                              |  |  |
| 2 to 0          | CEnCKS[2:0] | Communicat    | ion clock sett                                                            | ing.                                                            |                    |               |                              |  |  |
|                 |             | CEnCKS2       | CEnCKS1                                                                   | CEnCKS0                                                         | Operation clock    | Ν             | Comment                      |  |  |
|                 |             | 0             | 0                                                                         | 0                                                               | BRG disable        | -             | BRG stop for power<br>saving |  |  |
|                 |             | 0             | 0                                                                         | 1                                                               | PRSOUT/2           | 1             | See caution below            |  |  |
|                 |             | 0             | 1                                                                         | 0                                                               | PRSOUT/4           | 2             |                              |  |  |
|                 |             | 0             | 1                                                                         | 1                                                               | PRSOUT/6           | 3             |                              |  |  |
|                 |             | 1             | 0                                                                         | 0                                                               | PRSOUT/8           | 4             |                              |  |  |
|                 |             | 1             | 0                                                                         | 1                                                               | PRSOUT/10          | 5             |                              |  |  |
|                 |             | 1             | 1                                                                         | 0                                                               | PRSOUT/12          | 6             |                              |  |  |
|                 |             | 1             | 1                                                                         | 1                                                               | PRSOUT/14          | 7             |                              |  |  |
|                 |             | Caution: C    | EnMDL[2:0]                                                                | = [0,0,1] is pro                                                | ohibited when CEnC | CKS[          | 2:0] = [0,0,0].              |  |  |

## Table 13-6 CBnCTL1 register contents (2/2)



Refer to *"Transmission clock select function" on page 338* for further explanation on the transfer clock selection.

The baud rate for the transmission is calculated with the following formula:

$$baudrate = \frac{f_{QCSI}}{(2 \times N) \times 2^{K}} = \frac{f_{QCSI}}{N \times 2^{(K+1)}} = \frac{f_{QCSI}}{CEnMDL \times 2^{(CEnCKS+1)}}$$



Figure 13-2 Queued CSI Baud Rate Block Diagram



| (3)           | CEnCTL2 - Queued CSI control register 2 |                                                                                                                                                            |             |              |             |           |           |        |  |  |
|---------------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--------------|-------------|-----------|-----------|--------|--|--|
|               |                                         | The CEnCTL2 register is an 8-bit register that specifies the active voltage level of the chip select pins SCSEn0 to SCSEn3 and the Queued CSI data length. |             |              |             |           |           |        |  |  |
| Access        | This regis                              | ter can be                                                                                                                                                 | e read/writ | tten in 8-bi | t units.    |           |           |        |  |  |
| Address       | CE0CTL2<br>CE1CTL2                      |                                                                                                                                                            |             |              |             |           |           |        |  |  |
| Initial Value | 00 <sub>H</sub> . This                  | register is                                                                                                                                                | s cleared b | by any rese  | et.         |           |           |        |  |  |
|               | 7                                       | 6                                                                                                                                                          | 5           | 4            | 3           | 2         | 1         | 0      |  |  |
| CEnCTL2       | CEnCSL3                                 | CEnCSL2                                                                                                                                                    | CEnCSL1     | CEnCSL0      | CEnDL3      | CEnDL2    | CEnDL1    | CEnDL0 |  |  |
|               | R/W                                     | R/W                                                                                                                                                        | R/W         | R/W          | R/W         | R/W       | R/W       | R/W    |  |  |
| Caution       | Write to th                             |                                                                                                                                                            | L2 registe  | er is permit | tted only v | while CEn | TXE = 0 a | nd     |  |  |

**Note** To select the active level of the remaining pins, see *"CEnCTL4 - Queued CSI control register 4" on page 323* 

#### Table 13-7 CEnCTL2 register contents

| Bit<br>position | Bit name    | Function                                  | Function                                                                                                                                                                                                                                                                                           |             |                |                                        |  |  |  |  |  |
|-----------------|-------------|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------------|----------------------------------------|--|--|--|--|--|
| 7 to 4          | CEnCSL[3:0] | 0: Chip Sele<br>1: Chip Sele<br>Note: The | <ul> <li>Chip Select active level selection of SCSEnm pin:</li> <li>0: Chip Select signal SCSEnm is active low</li> <li>1: Chip Select signal SCSEnm is active high</li> <li>Note: The chip select settings will be reflected at the output pins immediately after the register is set.</li> </ul> |             |                |                                        |  |  |  |  |  |
| 3 to 0          | CEnDL[3:0]  | Transfer dat                              | ta length sp                                                                                                                                                                                                                                                                                       | ecification |                |                                        |  |  |  |  |  |
|                 |             | CEnDL3                                    | CEnDL2                                                                                                                                                                                                                                                                                             | CEnDL1      | CEnDL0         | Transfer data length                   |  |  |  |  |  |
|                 |             | 0                                         | 0                                                                                                                                                                                                                                                                                                  | 0           | 0              | Data length is 16 bits                 |  |  |  |  |  |
|                 |             | 0                                         | 0                                                                                                                                                                                                                                                                                                  | 0           | 1              | Setting prohibited                     |  |  |  |  |  |
|                 |             | 0                                         | 0                                                                                                                                                                                                                                                                                                  | 1           | х              |                                        |  |  |  |  |  |
|                 |             | 0                                         | 1                                                                                                                                                                                                                                                                                                  | х           | х              |                                        |  |  |  |  |  |
|                 |             | 1                                         | 0                                                                                                                                                                                                                                                                                                  | 0           | 0              | Data length is 8 bits                  |  |  |  |  |  |
|                 |             | 1                                         | 0                                                                                                                                                                                                                                                                                                  | 0           | 1              | Data length is 9 bits                  |  |  |  |  |  |
|                 |             | 1                                         | 0                                                                                                                                                                                                                                                                                                  | 1           | 0              | Data length is 10 bits                 |  |  |  |  |  |
|                 |             | 1                                         | 0                                                                                                                                                                                                                                                                                                  | 1           | 1              | Data length is 11 bits                 |  |  |  |  |  |
|                 |             | 1                                         | 1                                                                                                                                                                                                                                                                                                  | 0           | 0              | Data length is 12 bits                 |  |  |  |  |  |
|                 |             | 1                                         | 1                                                                                                                                                                                                                                                                                                  | 0           | 1              | Data length is 13 bits                 |  |  |  |  |  |
|                 |             | 1                                         | 1                                                                                                                                                                                                                                                                                                  | 1           | 0              | Data length is 14 bits                 |  |  |  |  |  |
|                 |             | 1                                         | 1 1 1 1 Data length is 15 bits                                                                                                                                                                                                                                                                     |             |                |                                        |  |  |  |  |  |
|                 |             |                                           | er to <i>"Data I</i><br>data length                                                                                                                                                                                                                                                                | •           | et function" o | on page 337 for further explanation on |  |  |  |  |  |



#### (4) CEnCTL3 - Queued CSI Control Register 3

The CEnCTL3 register is an 8-bit register that specifies the number of data elements to be transferred in block transfer mode.

Access This register can be read/written in 8-bit units.

Address CE0CTL3: FFFFFD4C<sub>H</sub> CE1CTL3: FFFFFD8C<sub>H</sub>

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|         | 7                 | 6                 | 5                 | 4                 | 3       | 2       | 1       | 0       |
|---------|-------------------|-------------------|-------------------|-------------------|---------|---------|---------|---------|
| CEnCTL3 | 0 <sup>Note</sup> | 0 <sup>Note</sup> | 0 <sup>Note</sup> | 0 <sup>Note</sup> | CEnSFN3 | CEnSFN2 | CEnSFN1 | CEnSFN0 |
|         | R/W               | R/W               | R/W               | R/W               | R/W     | R/W     | R/W     | R/W     |

Note Unused bits must be written as 0.

| Bit<br>position | Bit name    | Function                           |         |         |         |                           |  |
|-----------------|-------------|------------------------------------|---------|---------|---------|---------------------------|--|
| 3 to 0          | CEnSFN[3:0] | Transfer data number specification |         |         |         |                           |  |
|                 |             | CEnSFN3                            | CEnSFN2 | CEnSFN1 | CEnSFN0 | Transfer data number      |  |
|                 |             | 0                                  | 0       | 0       | 0       | Transfer 16 data elements |  |
|                 |             | 0                                  | 0       | 0       | 1       | Transfer 1 data element   |  |
|                 |             | 0                                  | 0       | 1       | 0       | Transfer 2 data elements  |  |
|                 |             | 0                                  | 0       | 1       | 1       | Transfer 3 data elements  |  |
|                 |             | 0                                  | 1       | 0       | 0       | Transfer 4 data elements  |  |
|                 |             | 0                                  | 1       | 0       | 1       | Transfer 5 data elements  |  |
|                 |             | 0                                  | 1       | 1       | 0       | Transfer 6 data elements  |  |
|                 |             | 0                                  | 1       | 1       | 1       | Transfer 7 data elements  |  |
|                 |             | 1                                  | 0       | 0       | 0       | Transfer 8 data elements  |  |
|                 |             | 1                                  | 0       | 0       | 1       | Transfer 9 data elements  |  |
|                 |             | 1                                  | 0       | 1       | 0       | Transfer 10 data elements |  |
|                 |             | 1                                  | 0       | 1       | 1       | Transfer 11 data elements |  |
|                 |             | 1                                  | 1       | 0       | 0       | Transfer 12 data elements |  |
|                 |             | 1                                  | 1       | 0       | 1       | Transfer 13 data elements |  |
|                 |             | 1                                  | 1       | 1       | 0       | Transfer 14 data elements |  |
|                 |             | 1                                  | 1       | 1       | 1       | Transfer 15 data elements |  |

#### Table 13-8 CEnCTL3register contents



#### (5) CEnCTL4 - Queued CSI control register 4

The CEnCTL4 register is an 8-bit register that specifies the active voltage level of the chip select pins SCSEn4 to SCSEn7, the alternative clock and data phase setting and that controls the enhanced chip select timing.

Access This register can be read/written in 8-bit units.

Address CE0CTL3: FFFFFD4C<sub>H</sub> CE1CTL3: FFFFFD8C<sub>H</sub>

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|         | 7                     | 6       | 5          | 4           | 3           | 2         | 1         | 0     |
|---------|-----------------------|---------|------------|-------------|-------------|-----------|-----------|-------|
| CE0CTL4 | CE0CSL7               | CE0CSL6 | CE0CSL5    | CE0CSL4     | CE0CPA      | CE0DPA    | CE00PE    | CE0MD |
|         | R/W                   | R/W     | R/W        | R/W         | R/W         | R/W       | R/W       | R/W   |
|         |                       |         |            |             |             |           |           |       |
| CE1CTL4 | 0                     | 0       | 0          | 0           | CE1CPA      | CE1DPA    | CE10PE    | CE1MD |
|         | R/W                   | R/W     | R/W        | R/W         | R/W         | R/W       | R/W       | R/W   |
|         |                       |         |            |             |             |           |           |       |
| Caution | Write to th<br>CEnRXE |         | L4 registe | er is permi | tted only v | vhile CEn | TXE = 0 a | nd    |

#### Table 13-9 CEnCTL4 register contents (1/2)

| Bit<br>position | Bit name    | Function                                                                                                                                                                                                                                                                                           |                                                            |                                                                                                                                                                                                                                                                                                                                                           |  |  |
|-----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 7 to 4          | CE0CSL[7:4] | <ul> <li>Chip Select active level selection of SCSE0m pin:</li> <li>0: Chip Select signal SCSE0m is active low</li> <li>1: Chip Select signal SCSE0m is active high</li> <li>Note: The chip select settings will be reflected at the output pins immediately after the register is set.</li> </ul> |                                                            |                                                                                                                                                                                                                                                                                                                                                           |  |  |
| 3               | CEnCPA      | Alternative clock and data phase selection                                                                                                                                                                                                                                                         |                                                            |                                                                                                                                                                                                                                                                                                                                                           |  |  |
| 2               | CEnDPA      | CEnCPA                                                                                                                                                                                                                                                                                             | CEnCPA CEnDPA Alternative Clock and Data phase s           |                                                                                                                                                                                                                                                                                                                                                           |  |  |
|                 |             | 0                                                                                                                                                                                                                                                                                                  | 0                                                          | Clock and data phase as CKP=0, DAP=0<br>(communication type 1)                                                                                                                                                                                                                                                                                            |  |  |
|                 |             | 0                                                                                                                                                                                                                                                                                                  | 1                                                          | Clock and data phase as CKP=0, DAP=1<br>(communication type 2)                                                                                                                                                                                                                                                                                            |  |  |
|                 |             | 1                                                                                                                                                                                                                                                                                                  | 0                                                          | Clock and data phase as CKP=1, DAP=0<br>(communication type 3)                                                                                                                                                                                                                                                                                            |  |  |
|                 |             | 1                                                                                                                                                                                                                                                                                                  | 1                                                          | Clock and data phase as CKP=1, DAP=1<br>(communication type 4)                                                                                                                                                                                                                                                                                            |  |  |
|                 |             | same Queu<br>(CKP/DAP)<br>active (CEn<br><b>Note:</b> Plea                                                                                                                                                                                                                                         | ed-CSI mad<br>or alternativ<br>OPE = 1). 7<br>ase refer to | the an alternative setting for the serial communication within the cro. Each chip select can be assigned to either the standard ve (CPA/DPA) phase setting when the enhanced timing is The CPA/DPA bits have no effect when CEnOPE = 0. the description "CEnCTL1 - Queued CSI control register 1" on etails on the timings for each clock and data phase. |  |  |



| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1               | CE00PE   | Enhanced timing enable/disable:<br>0: Enhanced timing is disabled<br>1: Enhanced timing is enabled.<br>When the enhanced timing is enabled (CEnOPE = 1), the setup time, inter-data time,<br>hold time and idle time for each chip select signal can be defined using the<br>CEnOPTm registers. For CEnOPE = 0, the standard timing applies to all chip select<br>signals.                                                                                                                                                                                                                                                                                                                                                                                 |
| 0               | CEOMD    | <ul> <li>Chip select mode specification:</li> <li>0: 4 chip select mode. Each of the 4 bits of the CEnCS register (CEnCS[3:0]) represents a chip select line.</li> <li>1: 8 chip select mode. The combination of the lower 3 bits of the CEnCS register (CEnCS[2:0]) select one out of 8 available chip select lines.</li> <li>4 chip select mode In 4 chip select mode, only 4 chip selects can be used for the communication, but multiple chip selects can be active for the same communication ("broadcast"), as each bit represents a chip select signal.</li> <li>8 chip select mode In 8 chip select mode, all 8 chip selects are accessible, although only one out of the 8 chip selects can be selected as active for a communication.</li> </ul> |

| Table 13-9 | CEnCTL4 register contents (2/2) |
|------------|---------------------------------|
|            |                                 |



| (6)           | CEnR    | CEnRX0 - Receive data buffer registers                                                                                                             |        |      |       |      |       |         |       |        |       |      |   |   |      |
|---------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------|--------|------|-------|------|-------|---------|-------|--------|-------|------|---|---|------|
|               |         | The CEnRX0 register is a 16-bit register or separated as upper 8 bits (CEnRX0H) and lower 8 bits (CEnRX0L), that is used to store receive data.    |        |      |       |      |       |         |       |        |       |      |   |   |      |
| Access        |         | This register can be read-only in 16-bit units, or in 8-bit units as CEnRX0L<br>register for lower 8 bits or as CEnRX0H register for upper 8 bits. |        |      |       |      |       |         |       |        |       |      |   |   |      |
| Address       |         | CE0RX0, CE0RX0L: FFFFD42 <sub>H</sub> CE0RX0H: FFFFFD43 <sub>H</sub><br>CE1RX0, CE1RX0L: FFFFFD82 <sub>H</sub> CE1RX0H: FFFFFD83 <sub>H</sub>      |        |      |       |      |       |         |       |        |       |      |   |   |      |
| Initial Value | • in si | <ul> <li>in single transfer mode (CEnCTL0.CEnTMS = 0): 0000H</li> </ul>                                                                            |        |      |       |      |       |         |       |        |       |      |   |   |      |
|               | • in bl | lock tran                                                                                                                                          | sfer r | node | e (CE | nCTL | _0.CI | EnTM    | S = ' | 1): ur | defir | ned. |   |   |      |
|               | 15      | 14 13                                                                                                                                              | 12     | 11   | 10    | 9    | 8     | 7       | 6     | 5      | 4     | 3    | 2 | 1 | 0    |
| CEnRX0        |         |                                                                                                                                                    |        |      |       | F    | Recei | ve data | a     |        |       |      |   |   |      |
| R             |         |                                                                                                                                                    |        |      |       |      |       |         |       |        |       |      |   |   |      |
|               |         |                                                                                                                                                    |        |      |       |      |       |         |       |        |       |      |   |   |      |
| Caution       | The re  | ceive da                                                                                                                                           |        |      | •     |      |       | idere   |       |        |       |      |   |   | on 🗌 |

The receive data buffer register is considered as emptied by the application software whenever the lower 8 bits of the register are read. It is therefore necessary to read CEnRX0H before CEnRX0L when 8-bit access is used.



#### (7) CEnCS - Chip select data buffer registers

The CEnCS register is a 16-bit register than can be also accessed as 8 bit register (CEnCSL) that stores Chip Select data.

Following the FIFO write pointer, the value written to CEnCS is stored in the FIFO data buffer as Chip Select bits. The value is stored to these bits when the transmit data is written to its register (CEnTX0 or CEnTX0L)

Access This register can be read/written in 8-bit or 16-bit units.

| Address | CE0CS, CE0CSL: | FFFFFD44 <sub>H</sub> |
|---------|----------------|-----------------------|
|         | CE1CS, CE1CSL: | FFFFFD84 <sub>H</sub> |

Initial Value FFFF<sub>H</sub>.

|       |   |   |   |   |   |   |   |   |   |   |   |   | 3          |            |            |            |
|-------|---|---|---|---|---|---|---|---|---|---|---|---|------------|------------|------------|------------|
| CEnCS | - | - | - | - | - | - | - | - | - | - | - | - | CEn<br>CS3 | CEn<br>CS2 | CEn<br>CS1 | CEn<br>CS0 |
|       |   |   |   |   |   |   |   | F | 3 |   |   |   | •          |            |            |            |

**Caution** 1. Write of CEnCS register is prohibited when CEnCTL0.CEnPWR = 0.

2. The Chip Select register is stored in the FIFO buffer when the transmit data is written to its register. It is therefore necessary to write the CEnCS register before the CEnTX0 (CEnTX0L) register.

3. In 8 chip select mode (CEnCTL4.CEnMD = 1) CEnCS3 must be set to 0.

Depending on the chip select mode (defined by the CEnMD flag - see *"CEnCTL4 - Queued CSI control register 4" on page 323* for details) the CEnCS[3:0] bits have a different meaning:

(a) CSIE0

• 4 chip select mode (CE0MD = 0)



#### Enhanced Queued Clocked Serial Interface (CSIE)

|        | CE0C   | S bits |        |          | Chip select signals |          |          |  |  |  |
|--------|--------|--------|--------|----------|---------------------|----------|----------|--|--|--|
| CE0CS3 | CE0CS2 | CE0CS1 | CE0CS0 | SCSE03   | SCSE02              | SCSE01   | SCSE00   |  |  |  |
| 0      | 0      | 0      | 0      | selected | selected            | selected | selected |  |  |  |
| 0      | 0      | 0      | 1      | selected | selected            | selected | -        |  |  |  |
| 0      | 0      | 1      | 0      | selected | selected            | -        | selected |  |  |  |
| 0      | 0      | 1      | 1      | selected | selected            | -        | -        |  |  |  |
| 0      | 1      | 0      | 0      | selected | -                   | selected | selected |  |  |  |
| 0      | 1      | 0      | 1      | selected | -                   | selected | -        |  |  |  |
| 0      | 1      | 1      | 0      | selected | _                   | -        | selected |  |  |  |
| 0      | 1      | 1      | 1      | selected | -                   | -        | -        |  |  |  |
| 1      | 0      | 0      | 0      | -        | selected            | selected | selected |  |  |  |
| 1      | 0      | 0      | 1      | _        | selected            | selected | -        |  |  |  |
| 1      | 0      | 1      | 0      | -        | selected            | -        | selected |  |  |  |
| 1      | 0      | 1      | 1      | -        | selected            | -        | -        |  |  |  |
| 1      | 1      | 0      | 0      | -        | -                   | selected | selected |  |  |  |
| 1      | 1      | 0      | 1      | -        | -                   | selected | -        |  |  |  |
| 1      | 1      | 1      | 0      | -        | -                   | -        | selected |  |  |  |
| 1      | 1      | 1      | 1      | —        | —                   | —        | —        |  |  |  |

Caution "When the enhanced timing mode is enabled by setting CEnCTL4.CEnOPE = 1, setting of CEnCS.CEnCS[3:0] = F<sub>H</sub> is prohibited."

#### • 8 chip select mode (CE0MD = 1)

| CE0CS3         | CE0CS2 | CE0CS1 | CE0CS0 | Active chip select signal |
|----------------|--------|--------|--------|---------------------------|
|                | 0      | 0      | 0      | SCSE00 selected           |
|                | 0      | 0      | 1      | SCSE01 selected           |
|                | 0      | 1      | 0      | SCSE02 selected           |
| 0 <sup>a</sup> | 0      | 1      | 1      | SCSE03 selected           |
| 0              | 1      | 0      | 0      | SCSE04 selected           |
|                | 1      | 0      | 1      | SCSE05 selected           |
|                | 1      | 1      | 0      | SCSE06 selected           |
|                | 1      | 1      | 1      | SCSE07 selected           |

a) In 8 chip select mode CE0CS3 must be set to 0.

#### (b) CSIE1: 4 chip select mode (CE1MD = 0)

- Note 1. The active level for each chip select is defined in the CEnCTL2 and CEnCTL4 register (CEnCSL[7:0] bits).
  - 2. In 4 chip select mode, multiple chip selects can be active at the same time. When enhanced timing is enabled in 4 chip select mode, the Queued-CSI macro will use the timing of the enabled chip select with the lowest number. But to ensure proper communication, it is mandatory that the timings of all chip selects that can be active at a same time are set to the same values.



### Enhanced Queued Clocked Serial Interface (CSIE)

|        | CE1C   | S bits |        |          | Chip sele | ct signals |          |
|--------|--------|--------|--------|----------|-----------|------------|----------|
| CE1CS3 | CE1CS2 | CE1CS1 | CE1CS0 | SCSE13   | SCSE12    | SCSE11     | SCSE10   |
| 0      | 0      | 0      | 0      | selected | selected  | selected   | selected |
| 0      | 0      | 0      | 1      | selected | selected  | selected   | -        |
| 0      | 0      | 1      | 0      | selected | selected  | -          | selected |
| 0      | 0      | 1      | 1      | selected | selected  | -          | -        |
| 0      | 1      | 0      | 0      | selected | -         | selected   | selected |
| 0      | 1      | 0      | 1      | selected | -         | selected   | -        |
| 0      | 1      | 1      | 0      | selected | -         | -          | selected |
| 0      | 1      | 1      | 1      | selected | -         | -          | -        |
| 1      | 0      | 0      | 0      | -        | selected  | selected   | selected |
| 1      | 0      | 0      | 1      | -        | selected  | selected   | -        |
| 1      | 0      | 1      | 0      | -        | selected  | -          | selected |
| 1      | 0      | 1      | 1      | -        | selected  | -          | -        |
| 1      | 1      | 0      | 0      | _        | -         | selected   | selected |
| 1      | 1      | 0      | 1      | -        | -         | selected   | -        |
| 1      | 1      | 1      | 0      | -        | -         | -          | selected |
| 1      | 1      | 1      | 1      | -        | -         | -          | —        |

Caution

"When the enhanced timing mode is enabled by setting CEnCTL4.CEnOPE = 1, setting of CEnCS.CEnCS[3:0] = F<sub>H</sub> is prohibited."



| (8)           | CEnTX0 - Transmission data buffer registers                                                                                                                                  |  |  |  |  |  |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|               | The CEnTX0 register is a 16-bit buffer register, or separated as upper 8 bits (CEnTX0H) and lower 8 bits (CEnTX0L), that stores transmission data.                           |  |  |  |  |  |
|               | Incrementing and following the FIFO buffer write pointer, the value written to CEnTX0 is stored to the FIFO buffer as transmission data.                                     |  |  |  |  |  |
| Access        | This register can be read/written in 16-bit units, or in 8-bit units as CEnTX0L register for lower 8 bits or as CEnTX0H register for upper 8 bits.                           |  |  |  |  |  |
| Address       | CE0TX0, CE0TX0L: FFFFD46 <sub>H</sub> CE0TX0H: FFFFD47 <sub>H</sub><br>CE1TX0, CE1TX0L: FFFFD86 <sub>H</sub> CE1TX0H: FFFFD87 <sub>H</sub>                                   |  |  |  |  |  |
| Initial Value | 0000 <sub>H</sub>                                                                                                                                                            |  |  |  |  |  |
| 05-710        | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                        |  |  |  |  |  |
| CEnTX0        | Receive data                                                                                                                                                                 |  |  |  |  |  |
|               | R                                                                                                                                                                            |  |  |  |  |  |
| Caution       | 1. Write to CEnTX0 register is prohibited when CEnPWR = 0.                                                                                                                   |  |  |  |  |  |
|               | <ol> <li>The transmit data buffer register is considered as written whenever the<br/>lower 8 bits of the register are written. It is therefore necessary to write</li> </ol> |  |  |  |  |  |

CEnTX0H before CEnTX0L when 8-bit access is used.



| (9)           |                                                                                                                                                                                                                            | <b>CEnSTR - Queued-CSI status registers</b><br>The CEnSTR register is an 8-bit register that shows the status of the Queued CSI. |        |        |                          |         |           |            |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|--------|--------|--------------------------|---------|-----------|------------|
| Access        | This regis<br>The bits C                                                                                                                                                                                                   |                                                                                                                                  |        |        |                          |         | read only | <i>y</i> . |
| Address       | CE0STR:<br>CE1STR:                                                                                                                                                                                                         |                                                                                                                                  |        |        |                          |         |           |            |
| Initial Value | 20 <sub>H</sub>                                                                                                                                                                                                            |                                                                                                                                  |        |        |                          |         |           |            |
|               | 7                                                                                                                                                                                                                          | 6                                                                                                                                | 5      | 4      | 3                        | 2       | 1         | 0          |
| CEnSTR        | CEnPCT                                                                                                                                                                                                                     | CEnFLF                                                                                                                           | CEnEMF | CEnTSF | CEnSFP3                  | CEnSFP2 | CEnSFP1   | CEnSFP0    |
|               | R/W                                                                                                                                                                                                                        | R                                                                                                                                | R      | R      | R                        | R       | R         | R          |
| Caution       | <ol> <li>CEnFLF, CEnEMF, CEnTSF and CEnSFP[3:0] are continuously updated<br/>with the current status of the Queued CSI. This means that a value read<br/>might be outdated shortly after the read was executed.</li> </ol> |                                                                                                                                  |        |        |                          |         |           |            |
|               | 2. When v interrup                                                                                                                                                                                                         | •                                                                                                                                |        |        | a element<br>indicate th |         | TFO, an o | verflow    |

### Table 13-10 CEnSTR register contents (1/2)

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                               |
|-----------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7               | CEnPCT   | FIFO buffer pointer clear command:<br>0: No operation<br>1: Clear all FIFO pointers to "0"                                                                                                                                                                                                             |
|                 |          | Note: Reading of the CEnPCT bit always returns "0".                                                                                                                                                                                                                                                    |
| 6               | CEnFLF   | FIFO buffer full status flag:<br>0: FIFO buffer is not full<br>1: FIFO buffer is full                                                                                                                                                                                                                  |
|                 |          | Note: The CEnFLFbit can only be read.                                                                                                                                                                                                                                                                  |
| 5               | CEnEMF   | FIFO buffer empty status flag:<br>0: FIFO buffer is not empty<br>1: FIFO buffer is empty                                                                                                                                                                                                               |
|                 |          | Note: The CEnEMFbit can only be read.                                                                                                                                                                                                                                                                  |
| 4               | CEnTSF   | Transmission status flag:<br>0: Idle state<br>1: Transmission in on going or preparing<br>In single transfer mode, this bit holds "1" from transmission start until FIFO empty.<br>In block transfer mode, this bit holds "1" from transmission start until finish transferring<br>all data to be sent |
|                 |          | <b>Note: 1.</b> The CEnTSFbit can only be read.                                                                                                                                                                                                                                                        |
|                 |          | <ol> <li>This bit is cleared to "0" by CEnCTL0.CEnPWR = 0 or<br/>(CEnCTL0.CEnTXE = 0 and CEnCTL0.CEnRXE = 0).</li> </ol>                                                                                                                                                                               |



| Bit<br>position | Bit name    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3 to 0          | CEnSFP[3:0] | <ul> <li>Transmission data count:</li> <li>In Single transfer mode, CEnSFP[3:0] indicates the number of remaining transfers in the FIFO. This value can be understood as (Write FIFO pointer) - (SIO load pointer)</li> <li>In FIFO transfer mode, CEnSFP[3:0] indicates the number of data transfers completed.<br/>In case of CEnSFP[3:0] = 0<sub>H</sub>:</li> <li>CEnEMF = 0 and CEnSFP[3:0] = 0<sub>H</sub>: Number of receptions completed = 0</li> <li>CEnEMF = 1 and CEnSFP[3:0] = 0<sub>H</sub>: Number of receptions completed = 16</li> <li>Note: The CEnSFP[3:0] bits hold its value until reset or CEnPCT = 1 is written.</li> </ul> |



#### (10) CEnOPTm - Queued CSI enhanced timing registers

The CEnOPTm registers are 16-bit register, that are used to define the timing for the chip select signal CEnm when enhanced timing is active (CEnOPE = 1). For a detailed description of the enhanced chip select timing refer to "Enhanced chip select timing" on page 348.

This register can be read/written in 16-bit units. Access

| Address | CE0OPT0: FFFFFD50 <sub>H</sub> | CE1OPT0: FFFFFD90 <sub>H</sub> |
|---------|--------------------------------|--------------------------------|
|         | CE0OPT1: FFFFFD52 <sub>H</sub> | CE1OPT1: FFFFFD92 <sub>H</sub> |
|         | CE0OPT2: FFFFFD54 <sub>H</sub> | CE1OPT2: FFFFFD94 <sub>H</sub> |
|         | CE0OPT3: FFFFFD56 <sub>H</sub> | CE1OPT3: FFFFFD96 <sub>H</sub> |
|         | CE0OPT4: FFFFFD58 <sub>H</sub> |                                |
|         | CE0OPT5: FFFFFD5A <sub>H</sub> |                                |
|         | CE0OPT6: FFFFFD5C <sub>H</sub> |                                |
|         | CE00PT7: FFFFFD5E <sub>H</sub> |                                |

Initial Value 0002<sub>H</sub>.

**CEnOPTm** 

|   | 15    | 14     | 13     | 12 | 11     | 10 | 9 | 8  | 7 | 6      | 5      | 4 | 3      | 2       | 1 | 0           |
|---|-------|--------|--------|----|--------|----|---|----|---|--------|--------|---|--------|---------|---|-------------|
| ı |       |        |        |    |        |    |   |    |   |        |        |   |        |         |   | CEn<br>SPm0 |
|   | i nom | IDEIII | IDIIIZ |    | IDIIIO |    |   | R/ |   | DEIIIO | INIIIZ |   | INIIIO | 01 1112 |   |             |

**Caution** 1. The CEnOPTm registers can be written only while CEnCTL0.CEnTXE = 0 and CEnCTL0.CEnRXE = 0.

2. CEnOPT4 to CEnOPT7 registers are not available for CSIE1.

#### Table 13-11 CEnOPTm register contents (1/3)

| Bit<br>position                                                            | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                |
|----------------------------------------------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15                                                                         | CEnPHSm  | <ul> <li>Clock/data phase selection:</li> <li>0: Clock/data phase selection defined by CKP/DAP are used for chip select m.</li> <li>1: Alternative clock/data phase selection defined by CKA/DAP are used for chip select m.</li> </ul>                                                                                                                                                 |
| CEnCS[3:0] bits. If the chip select<br>empty, the chip select stays active |          | <ul> <li>Chip select idle enforcement:</li> <li>0: Chip select m becomes idle whenever a different chip select value is defined the CEnCS[3:0] bits. If the chip select value remains the same or the buffer becomes empty, the chip select stays active.</li> <li>1: An idle state is always inserted after each transfer.</li> </ul>                                                  |
|                                                                            |          | <ul> <li>Note: When the multiple data is transferred using the same chip select setting, the chip select line remains active. The CEnIDLm bit forced the chip select line to become idle after each transfer, even if the same chip select setting is used for the next transfer.</li> <li>For more details refer to <i>"Enforced chip select idle setting" on page 348.</i></li> </ul> |



| Bit<br>position                                                                                                                                                                                                                                                 | Bit name    | Function                                |         |                                                                                        |                                                 |                             |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------------------------------|---------|----------------------------------------------------------------------------------------|-------------------------------------------------|-----------------------------|--|--|--|
| 13 to 11                                                                                                                                                                                                                                                        | CEnIDm[2:0] | Chip select m idle timing specification |         |                                                                                        |                                                 |                             |  |  |  |
|                                                                                                                                                                                                                                                                 |             | CEnIDm2                                 | CEnIDm1 | CEnIDm0                                                                                | Chip select m                                   | idle timing <sup>Note</sup> |  |  |  |
|                                                                                                                                                                                                                                                                 |             | 0                                       | 0       | 0                                                                                      | chip select m is idle fo                        | r 0 SCKE                    |  |  |  |
|                                                                                                                                                                                                                                                                 |             | 0                                       | 0       | 1                                                                                      | chip select m is idle fo                        | r 0.5 SCKE                  |  |  |  |
|                                                                                                                                                                                                                                                                 |             | 0                                       | 1       | 0                                                                                      | chip select m is idle fo                        | r 1 SCKE                    |  |  |  |
|                                                                                                                                                                                                                                                                 |             | 0                                       | 1       | 1                                                                                      | chip select m is idle fo                        | r 2 SCKE                    |  |  |  |
|                                                                                                                                                                                                                                                                 |             | 1                                       | 0       | 0                                                                                      | chip select m is idle fo                        | r 3 SCKE                    |  |  |  |
|                                                                                                                                                                                                                                                                 |             | 1                                       | 0       | 1                                                                                      | chip select m is idle fo                        | r 4 SCKE                    |  |  |  |
|                                                                                                                                                                                                                                                                 |             | 1                                       | 1       | 0                                                                                      | chip select m is idle fo                        | r 6 SCKE                    |  |  |  |
|                                                                                                                                                                                                                                                                 |             | 1                                       | 1       | 1                                                                                      | chip select m is idle fo                        | r 8 SCKE                    |  |  |  |
| Note:         A minimum idle period of around 2-3 macro clock cycles (for whenever a CS is set from active to inactive. This time is an time set by the CEnIDm[2:0] bits.           10 to 8         CEnHDm[2:0]         Chip select m hold timing specification |             |                                         |         |                                                                                        |                                                 |                             |  |  |  |
|                                                                                                                                                                                                                                                                 |             | CEnHDm2                                 |         | CEnHDm0                                                                                | Chip select m hold timing                       |                             |  |  |  |
|                                                                                                                                                                                                                                                                 |             | CEnHDm2                                 | CEnHDm1 |                                                                                        | CEnSIT=0                                        | CEnSIT=1                    |  |  |  |
|                                                                                                                                                                                                                                                                 |             | 0                                       | 0       | 0                                                                                      | no hold time                                    | 0.5 SCKE                    |  |  |  |
|                                                                                                                                                                                                                                                                 |             | 0                                       | 0       | 1                                                                                      | 0.5 SCKE                                        | 1 SCKE                      |  |  |  |
|                                                                                                                                                                                                                                                                 |             | 0                                       | 1       | 0                                                                                      | 1 SCKE                                          | 1.5 SCKE                    |  |  |  |
|                                                                                                                                                                                                                                                                 |             | 0                                       | 1       | 1                                                                                      | 2 SCKE                                          | 2.5 SCKE                    |  |  |  |
|                                                                                                                                                                                                                                                                 |             | 1                                       | 0       | 0                                                                                      | 3 SCKE                                          | 3.5 SCKE                    |  |  |  |
|                                                                                                                                                                                                                                                                 |             | 1                                       | 0       | 1                                                                                      | 4 SCKE                                          | 4.5 SCKE                    |  |  |  |
|                                                                                                                                                                                                                                                                 |             | 1                                       | 1       | 0                                                                                      | 6 SCKE                                          | 6.5 SCKE                    |  |  |  |
|                                                                                                                                                                                                                                                                 |             | 1                                       | 1       | 1                                                                                      | 8 SCKE                                          | 8.5 SCKE                    |  |  |  |
| <b>Note:</b> The hold times given above assume the transfer buffer. When the transfer of be longer than the times given above.                                                                                                                                  |             |                                         |         | ansfer queue becomes (                                                                 |                                                 |                             |  |  |  |
| 7, 6 CEnDL[1:0] Chip select m data length specification                                                                                                                                                                                                         |             |                                         |         |                                                                                        |                                                 |                             |  |  |  |
|                                                                                                                                                                                                                                                                 |             | CEnDLm1                                 | CEnDLm0 | EnDLm0 Chip select m dat                                                               |                                                 | length                      |  |  |  |
|                                                                                                                                                                                                                                                                 |             | 0                                       | ×       |                                                                                        | ngth defined by CEnCTL<br>gth for chip select m | .2.CEnDL[3:0] is used       |  |  |  |
|                                                                                                                                                                                                                                                                 |             | 1                                       | 0       | The data length for chip select m is 8 bits (regardless of CEnCTL2.CEnDL[3:0] setting) |                                                 |                             |  |  |  |
|                                                                                                                                                                                                                                                                 |             | 1                                       | 1       |                                                                                        | ngth for chip select m is<br>EnDL[3:0] setting) | 16 bits (regardless of      |  |  |  |

## Table 13-11 CEnOPTm register contents (2/3)



| Bit<br>position                                             | Bit name    | Function                                     |                                                 |               |                                       |                                                                                 |  |  |  |
|-------------------------------------------------------------|-------------|----------------------------------------------|-------------------------------------------------|---------------|---------------------------------------|---------------------------------------------------------------------------------|--|--|--|
| 5 to 3                                                      | CEnINm[2:0] | Chip select m inter-data delay specification |                                                 |               |                                       |                                                                                 |  |  |  |
|                                                             |             | CEnINm2                                      | CEnINm1                                         | CEnINm0       | Chip select m inter-data delay timing |                                                                                 |  |  |  |
|                                                             |             | CEIIINIIIZ                                   | CENINMI                                         | CEIIINIIIO    | CEnSIT=0                              | CEnSIT=1                                                                        |  |  |  |
|                                                             |             | 0                                            | 0                                               | 0             | no inter-data delay                   | 0.5 SCKE                                                                        |  |  |  |
|                                                             |             | 0                                            | 0                                               | 1             | 0.5                                   | SCKE                                                                            |  |  |  |
|                                                             |             | 0                                            | 1                                               | 0             | 1 S                                   | CKE                                                                             |  |  |  |
|                                                             |             | 0                                            | 1                                               | 1             | 2 S                                   | CKE                                                                             |  |  |  |
|                                                             |             | 1                                            | 0                                               | 0             | 3 S                                   | CKE                                                                             |  |  |  |
|                                                             |             | 1                                            | 0                                               | 1             | 4 S                                   | CKE                                                                             |  |  |  |
|                                                             |             | 1                                            | 1                                               | 0             | 6 SCKE                                |                                                                                 |  |  |  |
|                                                             |             | 1                                            | 1                                               | 1             | 8 SCKE                                |                                                                                 |  |  |  |
|                                                             |             | (C<br><b>2.</b> TI<br>w                      | CEnIDLm=0).<br>ne inter-data<br>aiting in the t | times given a | above assume that a n                 | enforced between data<br>ew transfer element is<br>eue becomes empty, the<br>e. |  |  |  |
| 2 to 0 CEnSPm[2:0] Chip select m setup timing specification |             |                                              |                                                 |               |                                       |                                                                                 |  |  |  |
|                                                             |             | CEnSPm2                                      | CEnSPm1                                         | CEnSPm0       | Chip select r                         | n setup timing                                                                  |  |  |  |
|                                                             |             | 0                                            | 0                                               | 0             | No setup delay                        |                                                                                 |  |  |  |
|                                                             |             | 0                                            | 0                                               | 1             | Setup delay is 0.5 SC                 | ЖЕ                                                                              |  |  |  |
|                                                             |             | 0                                            | 1                                               | 0             | Setup delay is 1 SCK                  | E                                                                               |  |  |  |
|                                                             |             | 0                                            | 1                                               | 1             | Setup delay is 2 SCK                  | E                                                                               |  |  |  |
|                                                             |             | 1                                            | 0                                               | 0             | Setup delay is 3 SCK                  | E                                                                               |  |  |  |
|                                                             |             | 1                                            | 0                                               | 1             | Setup delay is 4 SCK                  | E                                                                               |  |  |  |
|                                                             |             | 1                                            | 1                                               | 0             | Setup delay is 6 SCK                  | E                                                                               |  |  |  |
|                                                             |             | 1                                            | 1                                               | 1             | Setup delay is 8 SCK                  | E                                                                               |  |  |  |
|                                                             |             |                                              |                                                 |               |                                       |                                                                                 |  |  |  |

## Table 13-11 CEnOPTm register contents (3/3)



# **13.3 Explanation of Queued CSI Functions**

## 13.3.1 Transmit buffer

Chip select data and transmission data can be stored to the transmit FIFO buffer continuously by writing to the CEnCS register and CEnTX0 register. The Writing FIFO pointer is automatically incremented when data is written to CEnTX0. The size of the transmit FIFO buffer is 20 bits  $\times$  16 entries.

In slave mode, it is not necessary to set the chip select data.

The transfer start condition (assuming that CEnEMF = 0) is to write to the lower bits of CEnTX0 register. If the transmission data length is 9 bits or more, data should be written by a 16-bit write to CEnTX0 or by two 8-bit writes with first CEnTX0H, then CEnTX0L (in that order). When transmission data length is 8 bits, data should be set by one 8-bit write to CEnTX0L or by one 16-bit write to CEnTX0. For the 16-bit write the upper 8 bits are ignored in the 8-bit transmission.

The CEnFLF bit in the CEnSTR status register is set "1" after 16 writes have been made to the transmit buffer, assuming the Writing FIFO pointer was reset previously.

When a transmission write is attempted while the FIFO is full (CEnFLF=1), the interrupt INTCEnOFF is generated to indicate an overflow. In that case, the transmission and chip select data are discarded and not stored.

When a transfer cycle is finished and the SIO Loading FIFO pointer is incremented, the FIFO buffer of the previous location is considered empty in case of single transfer mode. Refer to *"Description of the block transfer mode"* on page 341 for more information on block transfer mode.



Figure 13-3 Transmit buffer



### 13.3.2 Serial data direction select function

The serial data direction is selectable using the CEnDIR bit in the CEnCTL0 register. The examples below show the communication for data length of 8 bit (CEnDL[3:0] = [1,0,0,0]):



Figure 13-4 Serial data direction select function - msb first (CEnDIR = 0)



Figure 13-5 Serial data direction select function - LSB first (CEnDIR = 0)



### 13.3.3 Data length select function

Transmission data length is selectable from 8 bits to 16 bits using the CEnDL[3:0] bits in CEnCTL2 register. The examples below show the communication with MSB first (CEnDIR = 1):



Figure 13-6 Data length select function

### 13.3.4 Slave mode

When the CEnCKS[2:0] bits in CEnCTL1 are set to [1,1,1], the Queued CSI operates in slave mode. In slave mode, the SCKE serial clock pin becomes input and another device is the CSI communication master. The baud rate generator "BRG" is recommended to be disabled by setting bits CEnMDL[2:0] to [0,0,0] when using slave mode. Also, the chip select pin SCSEn[3:0] outputs are not available in slave mode, as they are only available in master mode.

The example below shows the communication in slave mode for 8 data bits, CEnCKP=0, CEnDAP=0 and MSB first:







### 13.3.5 Master mode

When the CEnCKS[2:0] bits in CEnCTL1 are not set to [1,1,1], the Queued CSI operates in master mode. In master mode, the SCKE pin is configured as output and the serial communication clock is generated by the Queued CSI module. The SCKE pin's default value is "1" when CEnCKP = 1, and is default "0" when CEnCKP = 0. The SCSEn[3:0] pin outputs are available in master mode.

The example below shows the communication in master mode for 8 data bits, CEnCKP=0, CEnDAP=0 and MSB first:





### 13.3.6 Transmission clock select function

In Master Mode, the transfer baud rate is selectable using CEnCKS[2:0] bits and CEnMDL[2:0] bits in CEnCTL1 register. The baud rate generator "BRG" counts up at each rising edge of  $f_{QCSI}$ .

The example below illustrates the baud rate generation for CEnMDL[2:0] = [0,1,0].







## 13.3.7 Description of the single transfer mode



When the CEnTMS bit in the CEnCTL0 register is set "0", the Queued CSI operates in single transfer mode.

Figure 13-10 Single transfer mode data handling

Transfer start condition in single transfer mode:

[CEnTXE = 1 or CEnRXE = 1] and [Data exists in FIFO (CEnEMF = 0)]

A transfer starts once the transmission data (pointed to by the SIO Loading FIFO pointer) is transferred from the FIFO buffer to the serial shift register SIO. At that time, the transfer status flag CEnTSF turns to "1". The SCSEn[3:0] pins output the chip select data from the FIFO buffer.

At the end of the transfer:

- If CEnRX0 is empty, the received data is stored from SIO to CEnRX0, and transfer end interrupt signal INTCEnC is generated (in transmit only mode, INTCEnC will be generated only when the FIFO buffer becomes empty). Finally, the SIO Loading FIFO pointer is incremented.
- 2. If CEnRX0 is not empty, the storing of receive data, INTCEnC generation and SIO Loading FIFO pointer incrementing wait for the CEnRX0 to be emptied by a software read operation.
- 3. In transmit only mode, if transmission data is available in the FIFO buffer,



the next transfer will start immediately, regardless of the CEnRX0 buffer condition.

When a transfer finishes and the FIFO buffer is empty (Writing FIFO pointer = SIO Loading FIFO pointer), CEnTSF is cleared "0".

CEnSFP[3:0] always show the current value of: (Writing FIFO pointer) - (SIO Loading FIFO pointer).

It is recommended to check that CEnFLF = 0 just before data is written to the CEnTX0 register. If CEnFLF = 1 when a write to CEnTX0 is attempted, the overflow interrupt INTCEnOFF is generated and the written data is ignored.



Figure 13-11 Single transfer mode (master, transmit/receive) timing



### 13.3.8 Description of the block transfer mode



When the CEnTMS bit in the CEnCTL0 register is set "1", the Queued CSI operates in block transfer mode.

Figure 13-12 Block transfer mode data handling

Transfer start condition in block transfer mode:

[CEnTXE = 1 or CEnRXE = 1] and [Data exists in FIFO (CEnEMF = 0)]

The transmission data number must be set in CEnSFN[3:0]. Note that writing a value greater than 16 to the CEnCTL3 register is prohibited, as the FIFO buffer design can hold up to 16 elements only.

The transfer starts by copying the first data element - pointed to by SIO Load/Store FIFO pointer - to the SIO shift register. At that time the transmission status flag CEnTSF is set to "1", and the SCSEn[3:0] pins output the CS value from the FIFO.

When the transfer of the data element is finished, the received data overwrites the location in the FIFO using the SIO Load/Store FIFO pointer, and the SIO Load/Store FIFO pointer is then incremented.

When the transmission/reception counter reaches the value set by CEnSFN[3:0], then CEnTSF is cleared "0" and the transmission/reception end interrupt signal INTCEnC is generated.



After the interrupt occurred, the received data can be read from CEnRX0. The Read FIFO pointer is automatically incremented by the CEnRX0 read operation.

All FIFO pointers must be cleared by setting CEnPCT = 1 before the next transmit/receive cycle can start.

SFP[3:0] represents the [SIO Load/Store FIFO pointer] and shows the number of transmission/receptions completed. In case of SFP[3:0]=0H, the numbers of transmissions/receptions depends on the setting of the SFEMP bit:

SFEMP=0: 0 transmissions/receptions completed



SFEMP=1: 16 transmissions/receptions completed

Figure 13-13 Block transfer mode (master. transmit/receive) timing

## 13.3.9 Description of the operation modes

#### (1) Transmit only mode

Setting the CEnCTL0 register's CEnTXE =1 and CEnRXE = 0 places the Queued CSI in transmit only mode. A transmission starts when transmit data is written in the CEnTX0 register. The current condition of the CEnRX0 buffer and SIO register no effect. The data in the CEnRX0 and the SIO buffer is undefined after completion of the transmission.

### (2) Receive only mode

Setting the CEnCTL0 register's CEnTXE = 0 and CEnRXE = 1 places the Queued CSI in receive only mode. A reception starts when dummy data is written in the CEnTX0 register. It is mandatory, though, that the CEnRX0 and SIO are empty. If a receive operation is terminated while the previous receive data remains unread in CEnRX0, the Queued CSI is placed on wait status until the previous data is completely read and CEnRX0 becomes empty.



#### (3) Transmit/receive mode

Setting the CEnCTL0 register's CEnTXE = 1 and CEnRXE = 1 places the Queued CSI in transmit/receive mode. A transfer (meaning transmission and reception) starts when transmit data is written in the CEnTX0 register. Note that an empty CEnRX0 or SIO is mandatory. If a receive operation is terminated while the previous receive data remains unread in CEnRX0, the Queued CSI is placed on wait status until the previous data is completely read and CEnRX0 becomes empty.

In block transfer mode with slave mode, only the first dummy data write operation is required. There is no need to write chip-select data, as these bits are ignored.

## 13.3.10 Additional timing and delay selections

#### (1) Delay selection of receive termination interrupt signal (INTCEnC)

In master mode, the CEnSIT bit of the CEnCTL0 register can be used to delay the generation of the receive termination interrupt signal (INTCEnC) by a half serial clock cycle (SCKE). The CEnSIT bit takes effect only in the master mode and is ignored in slave mode.

*Figure 13-14* below illustrates the CEnSIT function, assuming a setting of CEnSIT=1, CEnWE=0, CEnCKP=0, CEnDAP=0 and CEnDL[3:0] = [1,0,0,0].



Figure 13-14 Delay selection of receive termination interrupt (INTCEnC)

### (2) Selection of transmit wait enable/disable

In master mode, while the enhanced timing is not enabled, the CEnCTL0 register's CEnWE bit setting can be used to delay the start of transmission by one SCKE clock cycle. The CEnWE bit takes effect only in the master mode and is ignored in slave mode.

*Figure 13-15* below illustrates the CEnWE function, assuming a setting of CEnWE=1, CEnCSM=0, CEnOPE=0, CEnCKP=0, CEnDAP=0 and CEnDL[3:0] = [1,0,0,0].





Figure 13-15 Selection of transmit wait enable/disable



#### (3) Selection of chip-select mode

In master mode with CEnWE = 1 and CEnOPE=0, the CEnCSM bit setting can be used to output an inactive level at the chip select pins SCSEn[3:0] during the delay between data transmissions. The CEnCSM bit takes effect only in the master mode and is ignored in slave mode.

The CEnCSM bit has no effect while CEnWE is set to 0.

*Figure 13-16* below illustrates the CEnCSM function, assuming a setting of CEnCKP=0, CEnDAP=0 and CEnDL[3:0] = [1,0,0,0].



Figure 13-16 Selection of chip-select mode



## 13.3.11 Default pin levels

#### (1) SCKE pin's default level

The SCKE pin's default level with the CEnCTL0 register settings CEnPWR=0 or (CEnTXE=0 and CEnRXE = 0) is as follows:

| CEnCKP | CEnCKS[2:0]                      | SCKE default level |        |
|--------|----------------------------------|--------------------|--------|
| 0      | 1, 1, 1 (slave mode)             | 1                  | ← Init |
| 0      | Other than 1, 1, 1 (master mode) | 1                  | res    |
| 4      | 1, 1, 1 (slave mode)             | 1                  |        |
|        | Other than 1, 1, 1 (master mode) | 0                  |        |

← Initialization after reset

Note In slave mode, the SCKE pin is always set to "1".

#### (2) SOE pin's default level

The SOE pin's default level with the CEnCTL0 register settings CEnPWR=0 or (CEnTXE=0 and CEnRXE=0) is as follows:

| SOE pin's default level |  |
|-------------------------|--|
| 0                       |  |

←Initialization after reset

#### (3) SCSEn0 to SCSEn7 pins' default level

The SCSEn0 to SCSEn7 pins' default level with the CEnCTL0 register settings CEnPWR=0 or (CEnTXE=0 and CEnRXE=0) is as follows:

| SCSEn0 to SCSEn7 pins'<br>default level |                                         |
|-----------------------------------------|-----------------------------------------|
| inactive                                | $\leftarrow$ Initialization after reset |



### 13.3.12 Transmit buffer overflow interrupt signal (INTCEnOF)

When the transmit FIFO buffer contains 16 elements, writing a 17th chip-select data (CEnCS write) or transfer data (CEnTX0 write) results in the generation of the overflow interrupt INTCEnOF. For the 17th item, both chip-select and transfer data values are discarded.

The transmit FIFO buffer contains 16 elements if the FIFO pointer value for the write operation equals the FIFO pointer value for the SIO load operation plus 15. When the transfer is completed and the FIFO buffer pointer for the SIO load operation is incremented, space for one element is available again in transmit buffer.



Figure 13-17 Transmit buffer overflow interrupt signal (INTCEnOF)



## 13.3.13 Enhanced chip select timing

### (1) General

The Enhanced Queued-CSI CSIE allows specific timing settings for each chip select line. The figure below shows the general timings of the chip select lines:





 $T_{SETUP}$  is the time between the chip select line becoming active and the first data bit to be transferred.  $T_{INTER}$  defines the delay between two transfers while the same chip select is chosen and active. After the last transfer, the chip select line remains active for a period set by  $T_{HOLD}$ . Last not least,  $T_{IDLE}$  can be used to delay the start of a new transfer with a different chip select setting.

Each delay time is set relative to the serial communication clock SCKE and can range from 0 (no delay) up to 8 serial clocks.

#### (2) Chip select deactivation

A chip select line is selected by writing the corresponding value to the CEnCS[3:0] bits. The chip select line remains active until a value is written to the CEnCS[3:0] bits that is different from the previous value.

The chip select line remains active even when the transfer queue becomes empty. After a new element is written in the transfer queue, either the inter-data or the hold timing will be applied before the new element is transmitted. In other words, the queue idle time will be seen in addition to the defined chip select timing.

#### (3) Multiple chip select activation

In 4 chip select mode, multiple chip selects can be active at the same time. When enhanced timing is enabled, the Queued-CSI macro will use the timing of the enabled chip select with the lowest number. But to ensure proper communication, it is mandatory that the timings of all chip selects that can be active at a same time are set to the same values.

### (4) Enforced chip select idle setting

The chip select line is hold active until the chip select setting of a transfer element changes. While this is suitable for most peripheral devices connected to the serial interface, some devices require an inactive state of the chip select line after each element transmitted.

The "Force Chip Select Idle" (CEnIDLm) bit is used to force this behaviour. *Figure 13-19* illustrates the difference between a standard communication and a communication with the CEnIDL1 bit set. It is assumed that the delay timings of CS2 are set as  $T_{INTER2}$ =0 and  $T_{HOLD2}$ =0, and that two elements are transferred to CS1 one before a transfer of two elements to CS2.

RENESAS



Figure 13-19 Enforced chip select idle example

While the timing for CEnIDL1=0 uses  $T_{INTER1}$  as between the two elements for CS1, the setting of CEnILD1=1 forces the  $T_{HOLD1}$ ,  $T_{IDLE1}$  and  $T_{SETUP1}$  delays for the chip select line between the elements.

#### (5) Hold, idle and setup timing relative to SCKE

The start of any timing is at the last valid data signal of the SCKE, not at the end of the SCKE cycle. *Figure 13-20* illustrates the timing. It is assumed that CKP=0, DAP=1,  $T_{HOLD1}=2$  SCKE,  $T_{IDLE1}=1$  SCKE,  $T_{SETUP2}=3$  SCKE, and that the data bits per element is 8:



Figure 13-20 Enhanced chip select timing extension relative to SCKE

With the setting of CKP=0 and DAP=1, data is output on the rising edge of SCKE and the data is valid at the falling edge. When the last data bit is sent, the interrupt is generated at the falling edge of the SCKE.



The next figure shows the timing with  $T_{HOLD1}=T_{IDLE1}=T_{SETUP2}=0$ , but CEnIDL1=1, CKP/DAP=0/0:



A small chip select idle pulse is generated after the "data valid" edge of SCKE, which is the rising edge in this example due to CKP=DAP=0.

#### (6) Impact of interrupt delay on enhanced timing

The CEnSIT bit allows to set a delay of half serial communication clock before the transfer complete interrupt is generated. This delay is inserted before any delay defined by the enhanced timing.

*Figure 13-21* shows as example a communication with  $T_{INTER1}=0$ ,  $T_{HOLD1}=0.5$ ,  $T_{IDLE1}=1$ ,  $T_{SETUP2}=0$  and  $T_{INTER2}=1$ , using single buffer transfer mode and 8-bit data length.



#### Figure 13-21 Enforced chip select idle timing extension

#### (7) Data phase details (dap=1) with enhanced timing

The DAP bit defines the phase of the data line relative to the serial clock. While the timing diagram for DAP=0 is straight forward, for DAP=1 there would be two options for the rising edge of the serial clock signal at the last data bit (DO0) when hold time is applied. Please use the figure below as reference.



The rising edge could be either done at the end of the DO0 bit, or it could be done at the end of the hold time (dashed line in the timing diagram). The Queued-CSI module places the rising edge at the end of the data bit.



Figure 13-22 Data phase details (DAP=1) with enhanced timing

#### (8) Change of clock phase and data phase

The enhanced timing also allows the definition of two clock polarity/data phase pairs. The following figures (*Figure 13-23* to *Figure 13-25*) illustrate the transition in polarity down to internal Queued-CSI operating clock level. In a nutshell, there is one macro clock delay between the change in polarity and the activation of the chip select signal.

Except when noted otherwise, it is assumed in the following examples that there is no setup delay defined for CS2. If a delay is defined, the standard rules would apply after the activation of the chip select signal.

**Caution** *Figure 13-23* shows the synchronisation delay after the new CS signal is activated, while in the other figures the synchronisation delay is ignored to simplify the drawings. The synchronization delay would apply, though!



Figure 13-23 shows the transition from SCSE0 with (CKP=0, DAP=0) to SCSE1 with (CKA=1, DPA=0), using the following settings:  $T_{HOLD0}=0$ ,  $T_{IDLE0}=1$ ,  $T_{SETUP1}=0.5$ ,  $f_{SCKE}=f_{QCSI}/16$ :





- 1. Is the last first half of the last data bit sent with SCSE0 active
- 2. At the rising edge of SCKE, the interrupt signal is generated.
- Represents the idle time (T<sub>IDLE0</sub>=1). One f<sub>QCSI</sub> clock after the generation of the interrupt signal, SCSE0 is set to inactive. It is hold inactive for serial clock cycle plus one internal clock f<sub>QCSI</sub>.
- 4. After the idle time, the serial clock polarity is changed due to the CKA=1 transition.
- 5. One internal clock  $f_{QCSI}$  after the change of the clock polarity SCSE1 is set to active. Then the timing is synchronized with the internal baud rate generator that operates continuously at  $f_{QCSI}/8$ .
- 6. Is the setup delay of SCSE1 (T<sub>SETUP1</sub>=0.5).
- 7. Is the output of the first data bit with SCSEn1 active.





Figure 13-24 CKP=0, DAP=0 to CKA=1, DPA=1 with enhanced timing



Figure 13-25 CKP=1, DAP=0 to CKA=0, DPA=1 with enhanced timing





Figure 13-26 CKP=1, DAP=0 to CKA=0, DPA=0 with enhanced timing



# 13.4 Operating Procedure

## 13.4.1 Single transfer mode (master mode, transmit only mode)

MSB first (CEnDIR = 0), no INTCEnC delay (CEnSIT=0), transmission wait disabled (CEnWE = 0),

CS inactive disabled (CEnCSM = 0), CEnCKP = 0, CEnDAP = 0, transmission data length of 8 bits (CEnDL[3:0] = [1,0,0,0]):



Figure 13-27 Single transfer mode (master, transmit only) timing

- 1. Set the CEnCTL0 register's CEnPWR bit to 1 to enable the supply of the Queued CSI operation clock.
- 2. Set the CEnCTL1 and CEnCTL2 registers to specify the transfer mode.
- 3. Write "1" in the CEnSTR register's CEnPCT bit to clear all FIFO pointers.
- 4. Specify the transfer mode using the CEnCTL0 register's CEnTMS, CEnDIR, and CEnSIT bits; at the same time, set the CEnTXE bit to 1 to enable transmission.
- 5. Make sure that the CEnSTR register's CEnFLF bit is set to 0, then write chip-select data and transmission data in the CEnCS and CEnTX0 registers in this order.

Repeat step (5) until the last element to be transmitted is written in the CEnCS/CEnTX0 registers.

6. Verify that CEnSTR.CEnTSF = 0 (CSIEn in idle state) and set the CEnCTL0 register's CEnTXE bit to 0 to disable transmission (end of transmission).



### 13.4.2 Single transfer mode (master mode, receive only mode)

MSB first (CEnDIR = 0), no INTCEnC delay (CEnSIT = 0), transmission wait disabled (CEnWE = 0), CS inactive disabled (CEnCSM = 0), CEnCKP = 0, CEnDAP = 1, transmission data length of 8 bits (CEnDL[3:0] = [1,0,0,0]):





- 1. Set the CEnCTL0 register's CEnPWR bit to 1 to enable the supply of the Queued CSI operation clock.
- 2. Set the CEnCTL1 and CEnCTL2 registers to specify the transfer mode.
- 3. Write "1" in the CEnSTR register's CEnPCT bit to clear all FIFO pointers.
- Specify the transfer mode using the CEnCTL0 register's CEnTMS, CEnDIR, and CEnSIT bits; at the same time, set the CEnRXE bit to 1 to enable the receive operation.
- 5. Make sure that the CEnSTR register's CEnFLF bit is set to 0, then write chip-select data and dummy transmission data in the CEnCS and CEnTX0 registers in this order (start-of-receive trigger).
- 6. Check for a reception to be completed by monitoring the INTCEnC interrupt. If so, read the CEnRX0 register.

Repeat steps (5) and (6) until the last element is received and read from the CEnRX0 register.

- Verify that CEnSTR.CEnTSF = 0 (CSIEn in idle state) and set the CEnCTL0 register's CEnRXE bit to 0 to disable the receive operation (end of receive operation).
- **Note** The SOE pin is invalid and maintains its signal level, as the output latch is disabled.



### 13.4.3 Single transfer mode (master mode, transmit/receive mode)

MSB first (CEnDIR = 0), no INTCEnC delay (CEnSIT = 0), transmission wait disabled (CEnWE = 0), CS inactive disabled (CEnCSM = 0), CEnCKP = 1, CEnDAP = 0, transmission data length of 8 bits (CEnDL[3:0] = [1,0,0,0]):



Figure 13-29 Single transfer mode (master, transmit/receive) timing

- 1. Set the CEnCTL0 register's CEnPWR bit to 1 to enable the supply of the Queued CSI operation clock.
- 2. Set the CEnCTL1 and CEnCTL2 registers to specify the transfer mode.
- 3. Write "1" in the CEnSTR register's CEnPCT bit to clear all FIFO pointers.
- Specify the transfer mode using the CEnCTL0 register's CEnTMS, CEnDIR, and CEnSIT bits; at the same time, set the CEnTXE and CEnRXE bits to 1 to enable the transmit/receive operation.
- 5. Make sure that the CEnSTR register's CEnFLF bit is set to 0, then write chip-select data and transmission data in the CEnCS and CEnTX0 registers in this order.
- 6. Check for a transmission to be finished by monitoring the INTCEnC interrupt. If so, read the CEnRX0 register.

Repeat steps (5) and (6) until the last element is send/received and read from the CEnRX0 register.

 Verify that CEnSTR.CEnTSF = 0 (CSIEn in idle state) and set the CEnCTL0 register's CEnTXE and CEnRXE bits to 0 to disable the transmit/receive operation (end of transmit/receive operation).



### 13.4.4 Single transfer mode (slave mode, transmit only mode)

MSB first (CEnDIR = 0), no INTCEnC delay (CEnSIT = 0), transmission wait disabled (CEnWE = 0), CS inactive disabled (CEnCSM = 0), CEnCKP = 1, CEnDAP = 1, transmission data length of 8 bits (CEnDL[3:0] = [1,0,0,0]):



Figure 13-30 Single transfer mode (slave, transmit only) timing

- 1. Set the CEnCTL0 register's CEnPWR bit to 1 to enable the supply of the Queued CSI operation clock.
- 2. Set the CEnCTL1 and CEnCTL2 registers to specify the transfer mode.
- 3. Write "1" in the CEnSTR register's CEnPCT bit to clear all FIFO pointers.
- 4. Specify the transfer mode using the CEnCTL0 register's CEnTMS, CEnDIR, and CEnSIT bits; at the same time, set the CEnTXE bit to 1 to enable transmission.
- 5. Make sure that the CEnSTR register's CEnFLF bit is set to 0, then write transmission data in the CEnTX0 register. (In the slave mode, there is no need to set data in the CEnCS register, as the chip select pins SCSEn[3:0] are not used.)

Repeat step (5) until the last element to be transmitted is written in the CEnTX0 register.

6. Verify that CEnSTR.CEnTSF = 0 (CSIEn in idle state) and set the CEnCTL0 register's CEnTXE bit to 0 to disable transmission (end of transmission).

To continue transmission, repeat step (5) before executing step (6).



### 13.4.5 Single transfer mode (slave mode, receive only mode)

MSB first (CEnDIR = 0), no INTCEnC delay (CEnSIT = 0), transmission wait disabled (CEnWE = 0), CS inactive disabled (CEnCSM = 0), CEnCKP = 0, CEnDAP = 0, transmission data length of 8 bits (CEnDL[3:0] = [1,0,0,0]):



Figure 13-31 Single transfer mode (slave, receive only) timing

- 1. Set the CEnCTL0 register's CEnPWR bit to 1 to enable the supply of the Queued CSI operation clock.
- 2. Set the CEnCTL1 and CEnCTL2 registers to specify the transfer mode.
- 3. Write "1" in the CEnSTR register's CEnPCT bit to clear all FIFO pointers.
- Specify the transfer mode using the CEnCTL0 register's CEnTMS, CEnDIR, and CEnSIT bits; at the same time, set the CEnRXE bit to 1 to enable the receive operation.
- Make sure that the CEnSTR register's CEnFLF bit is set to 0, then write dummy transmission data in the CEnTX0 register (start-of-receive trigger). (In the slave mode, there is no need to set data in the CEnCS register, as the chip select pins SCSEn[3:0] are not used.)
- 6. Check for a reception to be completed by monitoring the INTCEnC interrupt. If so, read the CEnRX0 register.

Repeat steps (5) and (6) until the last element is received and read from the CEnRX0 register.

- Verify that CEnSTR.CEnTSF = 0 (CSIEn in idle state) and set the CEnCTL0 register's CEnRXE bit to 0 to disable the receive operation (end of receive operation).
- **Note** The SOEn pin is invalid and maintaining its signal level, as the output latch is disabled.



## 13.4.6 Single transfer mode (slave mode, transmit/receive mode)

MSB first (CEnDIR = 0), no INTCEnC delay (CEnSIT = 0), transmission wait disabled (CEnWE = 0), CS inactive disabled (CEnCSM = 0), CEnCKP = 0, CEnDAP = 1, transmission data length of 8 bits (CEnDL[3:0] = [1,0,0,0]):



Figure 13-32 Single transfer mode (slave, transmit/receive) timing

- 1. Set the CEnCTL0 register's CEnPWR bit to 1 to enable the supply of the Queued CSI operation clock.
- 2. Set the CEnCTL1 and CEnCTL2 registers to specify the transfer mode.
- 3. Write "1" in the CEnSTR register's CEnPCT bit to clear all FIFO pointers.
- 4. Specify the transmit mode using the CEnCTL0 register's CEnTMS, CEnDIR, and CEnSIT bits; at the same time, set the CEnTXE and CEnRXE bits to 1 to enable the transmit/receive operation.
- 5. Make sure that the CEnSTR register's CEnFLF bit is set to 0, then write transmission data in the CEnTX0 register. (In the slave mode, there is no need to set data in the CEnCS register, as the chip select pins SCSEn[3:0] are not used.)
- 6. Check for a reception to be completed by monitoring the INTCEnC interrupt. If so, read the CEnRX0 register.

Repeat steps (5) and (6) until the last element is send/received and read from the CEnRX0 register.

 Verify that CEnSTR.CEnTSF = 0 (CSIEn in idle state) and set the CEnCTL0 register's CEnTXE and CEnRXE bits to 0 to disable the transmit/receive operation (end of transmit/receive operation).



#### 13.4.7 Block transfer mode (master mode, transmit only mode)

MSB first (CEnDIR = 0), no INTCEnC delay (CEnSIT = 0), transmission wait disabled (CEnWE = 0), CS inactive disabled (CEnCSM = 0), CEnCKP = 0, CEnDAP = 0, transmission data length of 8 bits (CEnDL[3:0] = [1,0,0,0]):



Figure 13-33 Block transfer mode (master, transmit only) timing

- 1. Set the CEnCTL0 register's CEnPWR bit to 1 to enable the supply of the Queued CSI operation clock.
- 2. Set the CEnCTL1 and CEnCTL2 registers to specify the transfer mode.
- 3. Write "1" in the CEnSTR register's CEnPCT bit to clear all FIFO pointers.
- Specify the transfer mode using the CEnCTL0 register's CEnTMS, CEnDIR, and CEnSIT bits; at the same time, set the CEnTXE bit to 1 to enable transmission.
- 5. Set the number of send-data items in the CEnCTL3 register's CEnSFN[3:0] bits.
- 6. Make sure that the CEnSTR register's CEnFLF bit is set to 0, then write chip-select data and transmission data in the CEnCS and CEnTX0 registers in this order.
- 7. Wait for the transmissions to be completed by monitoring the INTCEnC interrupt.
- 8. Write "1" in the CEnSTR register's CEnPCT bit and clear all FIFO pointers for the next transmission.

To continue transmission, repeat steps (5) - (8).

 Verify that CEnSTR.CEnTSF = 0 (CSIEn in idle state) and set the CEnCTL0 register's CEnTXE bit to 0 to disable transmission (end of transmission).



#### 13.4.8 Block transfer mode (master mode, receive only mode)

MSB first (CEnDIR = 0), no INTCEnC delay (CEnSIT = 0), transmission wait disabled (CEnWE = 0), CS inactive disabled (CEnCSM = 0), CEnCKP = 0, CEnDAP = 1, transmission data length of 8 bits (CEnDL[3:0] = [1,0,0,0]):



Figure 13-34 Block transfer mode (master, receive only) timing

- 1. Set the CEnCTL0 register's CEnPWR bit to 1 to enable the supply of the Queued CSI operation clock.
- 2. Set the CEnCTL1 and CEnCTL2 registers to specify the transfer mode.
- 3. Write "1" in the CEnSTR register's CEnPCT bit to clear all FIFO pointers.
- Specify the transfer mode using the CEnCTL0 register's CEnTMS, CEnDIR, and CEnSIT bits; at the same time, set the CEnRXE bit to 1 to enable the receive operation.
- 5. Set the number of receive-data items in the CEnCTL3 register's CEnSFN[3:0] bits.
- 6. Make sure that the CEnSTR register's CEnFLF bit is set to 0, then write chip-select data and dummy transmission data in the CEnCS and CEnTX0 registers in this order (start-of-receive trigger).
- 7. Wait for the receptions to be completed by monitoring the INTCEnC interrupt.
- 8. Read the received data by multiple read of the CEnRX0 register (= sequential read from the FIFO).
- 9. Write "1" in the CEnSTR register's CEnPCT bit and clear all FIFO pointers for the next transmission.

To continue reception, repeat steps (5) - (9).

- 10. Verify that CEnSTR.CEnTSF = 0 (CSIEn in idle state) and set the CEnCTL0 register's CEnRXE bit to 0 to disable the receive operation (end of receive operation).
- Note The SOEn pin is invalid and maintains its signal level, as the output latch is disabled.



#### 13.4.9 Block transfer mode (master mode, transmit/receive mode)

MSB first (CEnDIR = 0), no INTCEnC delay (CEnSIT = 0), transmission wait disabled (CEnWE = 0), CS inactive disabled (CEnCSM = 0), CEnCKP = 1, CEnDAP = 0, transmission data length of 8 bits (CEnDL[3:0] = [1,0,0,0]):



Figure 13-35 Block transfer mode (master, transmit/receive) timing

- 1. Set the CEnCTL0 register's CEnPWR bit to 1 to enable the supply of the Queued CSI operation clock.
- 2. Set the CEnCTL1 and CEnCTL2 registers to specify the transfer mode.
- 3. Write "1" in the CEnSTR register's CEnPCT bit to clear all FIFO pointers.
- 4. Specify the transfer mode using the CEnCTL0 register's CEnTMS, CEnDIR, and CEnSIT bits; at the same time, set the CEnTXE and CEnRXE bits to 1 to enable the transmit/receive operation.
- 5. Set the number of transmit/receive data items in the CEnCTL3 register's CEnSFN[3:0] bits.
- 6. Make sure that the CEnSTR register's CEnFLF bit is set to 0, then write chip-select data and transmission data in the CEnCS and CEnTX0 registers in this order.
- 7. Wait for the transmissions/receptions to be completed by monitoring the INTCEnC interrupt.
- 8. Read the received data by multiple read of the CEnRX0 register (= sequential read from the FIFO).
- 9. Write "1" in the CEnSTR register's CEnPCT bit and clear all FIFO pointers for the next transmission.

To continue transmission/reception, repeat steps (5) - (9).

10. Verify that CEnSTR.CEnTSF = 0 (CSIEn in idle state) and set the CEnCTL0 register's CEnTXE and CEnRXE bits to 0 to disable the transmit/receive operation (end of transmit/receive operation).



#### 13.4.10 Block transfer mode (slave mode, transmit only mode)

MSB first (CEnDIR = 0), no INTCEnC delay (CEnSIT = 0), transmission wait disabled (CEnWE = 0), CS inactive disabled (CEnCSM = 0), CEnCKP = 1, CEnDAP = 1, transmission data length of 8 bits (CEnDL[3:0]= [1,0,0,0]):



Figure 13-36 Block transfer mode (slave, transmit only) timing

- 1. Set the CEnCTL0 register's CEnPWR bit to 1 to enable the supply of the Queued CSI operation clock.
- 2. Set the CEnCTL1 and CEnCTL2 registers to specify the transfer mode.
- 3. Write "1" in the CEnSTR register's CEnPCT bit to clear all FIFO pointers.
- Specify the transfer mode using the CEnCTL0 register's CEnTMS, CEnDIR, and CEnSIT bits; at the same time, set the CEnTXE bit to 1 to enable transmission.
- 5. Set the number of send-data items in the CEnCTL3 register's CEnSFN[3:0] bits.
- 6. Make sure that the CEnSTR register's CEnFLF bit is set to 0, then write transmission data in the CEnTX0 register. (In the slave mode, there is no need to set data in the CEnCS register, as the chip select pins SCSEn[3:0] are not used.)
- 7. Wait for the transmissions to be completed by monitoring the INTCEnC interrupt.
- 8. Write "1" in the CEnSTR register's CEnPCT bit and clear all FIFO pointers for the next transmission.

To continue transmission, repeat steps (5) - (8).

 Verify that CEnSTR.CEnTSF = 0 (CSIEn in idle state) and set the CEnCTL0 register's CEnTXE bit to 0 to disable transmission (end of transmission).



#### 13.4.11 Block transfer mode (slave mode, receive only mode)

MSB first (CEnDIR = 0), no INTCEnC delay (CEnSIT = 0), transmission wait disabled (CEnWE = 0), CS inactive disabled (CEnCSM = 0), CEnCKP = 0, CEnDAP = 0, transmission data length of 8 bits (CEnDL[3:0] = [1,0,0,0]):



Figure 13-37 Block transfer mode (slave, receive only) timing

- 1. Set the CEnCTL0 register's CEnPWR bit to 1 to enable the supply of the Queued CSI operation clock.
- 2. Set the CEnCTL1 and CEnCTL2 registers to specify the transfer mode.
- 3. Write "1" in the CEnSTR register's CEnPCT bit to clear all FIFO pointers.
- Specify the transfer mode using the CEnCTL0 register's CEnTMS, CEnDIR, and CEnSIT bits; at the same time, set the CEnRXE bit to 1 to enable the receive operation.
- 5. Set the number of receive-data items in the CEnCTL3 register's CEnSFN[3:0] bits.
- 6. Make sure that the CEnSTR register's CEnFLF bit is set to 0, then write dummy transmission data in the CEnTX0 register (start-of-receive trigger). (In the slave mode, there is no need to set data in the CEnCS register, as the chip select pins SCSEn[3:0] are not used.)
- 7. Wait for the receptions to be completed by monitoring the INTCEnC interrupt.
- 8. Read the received data by multiple read of the CEnRX0 register (= sequential read from the FIFO).
- 9. Write "1" in the CEnSTR register's CEnPCT bit and clear all FIFO pointers for the next transmission.

To continue reception, repeat steps (5) - (9).

- 10. Verify that CEnSTR.CEnTSF = 0 (CSIEn in idle state) and set the CEnCTL0 register's CEnRXE bit to 0 to disable the receive operation (end of receive operation).
- **Note** The SOEn pin is invalid and maintains its signal level, as the output latch is disabled.



### 13.4.12 Block transfer mode (slave mode, transmit/receive mode)

MSB first (CEnDIR = 0), no INTCEnC delay (CEnSIT = 0), transmission wait disabled (CEnWE = 0), CS inactive disabled (CEnCSM = 0), CEnCKP = 0, CEnDAP = 1, transmission data length of 8 bits (CEnDL[3:0] = [1,0,0,0]):



Figure 13-38 Block transfer mode (slave, transmit/receive) timing

- 1. Set the CEnCTL0 register's CEnPWR bit to 1 to enable the supply of the Queued CSI operation clock.
- 2. Set the CEnCTL1 and CEnCTL2 registers to specify the transfer mode.
- 3. Write "1" in the CEnSTR register's CEnPCT bit to clear all FIFO pointers.
- Specify the transfer mode using the CEnCTL0 register's CEnTMS, CEnDIR, and CEnSIT bits; at the same time, set the CEnTXE and CEnRXE bits to 1 to enable the transmit/receive operation.
- 5. Set the number of transmit/receive data items in the CEnCTL3 register's CEnSFN[3:0] bits.
- 6. Make sure that the CEnSTR register's CEnFLF bit is set to 0, then write transmission data in the CEnTX0 register. (In the slave mode, there is no need to set data in the CEnCS register, as the chip select pins SCSEn[3:0] are not used.)
- 7. Wait for the transmissions/receptions to be completed by monitoring the INTCEnC interrupt.
- 8. Read the received data by multiple read of the CEnRX0 register (= sequential read from the FIFO).
- 9. Write "1" in the CEnSTR register's CEnPCT bit and clear all FIFO pointers for the next transmission.

To continue transmission, repeat steps (5) - (9).

10. Verify that CEnSTR.CEnTSF = 0 (CSIEn in idle state) and set the CEnCTL0 register's CEnTXE and CEnRXE bits to 0 to disable the transmit/receive operation (end of transmit/receive operation).



## 13.5 Cautions

#### 13.5.1 Inconsistent read data in master mode

**Description** Data read from the CEnRx0 register may be incorrect due to a wrong data width being applied to the received data. The behaviour occurs if all of the following conditions are met:

- Enhanced timing mode is used (CEnCTL4.CEnOPE = 1)
- Different data width configured for each chip select SCSEnm (different CEnOPTm.CEnDLm[1:0])
- Master mode is enabled (CEnCTL1.CEnCKS[2:0]  $\neq$  111<sub>B</sub>]
- Receive or Transmit-Receive is enabled (CEnCTL0.CEnRXE = 1)
- Serial data direction is LSB first (CEnCTL0.CEnDIR = 1)
- Workaround Configure the CSIEn in such a way that not all of above mentioned conditions apply, e.g. use MSB first or configure the same data length for each chip select SCSEnm.

#### 13.5.2 Transmit/receive enable after CEnTX0 write

**Description** If transmission (CEnCTL0.CEnTXE = 1) or reception (CEnCTL0.CEnRXE = 1) is enabled after writing data to the transmission data buffer register CEnTX0 the receive/transmission operation may fail.

Workaround Enable transmission/reception before writing to CEnTX0.



## Chapter 14 CAN Controller (CAN)

The microcontroller features an on-chip 2-channel CAN (Controller Area Network) controller that complies with the CAN protocol as standardized in ISO 11898.

- Throughout this chapter, the individual CAN channels are identified by "n" (n = 0, 1), for example CANn, or CnGMCTRL for the CANn global control register.
  - Throughout this chapter, the CAN message buffer registers are identified by "m" (m = 0 to 31), for example COMDATA4m for CAN0 message data byte 4 of message buffer register m.

## 14.1 Features

- Compliant with ISO 11898 and tested according to ISO/DIS 16845 (CAN conformance test)
- Standard frame and extended frame transmission/reception enabled
- Transfer rate: 1 Mbps max. (if CAN clock input  $\ge$  8 MHz, for 32 channels)
- 32 message buffers per channel
- Receive/transmit history list function
- Automatic block transmission function
- Multi-buffer receive block function
- Mask setting of four patterns is possible for each channel
- Data bit time, communication baud rate and sample point can be controlled by CAN module bit-rate prescaler register (CnBRP) and bit rate register (CnBTR)
  - As an example the following sample-point configurations can be configured:
  - 66.7%, 70.0%, 75.0%, 80.0%, 81.3%, 85.0%, 87.5%
  - Baud rates in the range of 10 kbps up to 1000 kbps can be configured
- Enhanced features:
  - Each message buffer can be configured to operate as a transmit or a receive message buffer
  - Transmission priority is controlled by the identifier or by mailbox number (selectable)
  - A transmission request can be aborted by clearing the dedicated Transmit-Request flag of the concerned message buffer.
  - Automatic block transmission operation mode (ABT)
  - Time stamp function for CAN channels 0 to n in collaboration with timers capture channels



### 14.1.1 Overview of functions

Table 14-1 presents an overview of the CAN Controller functions.

| Table 14-1 | Overview of functions |
|------------|-----------------------|
|            |                       |

| Function                   | Details                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Protocol                   | CAN protocol ISO 11898 (standard and extended frame transmission/reception)                                                                                                                                                                                                                                                                                                                                                 |  |  |
| Baud rate                  | Maximum 1 Mbps (CAN clock input ≥ 8 MHz)                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| Data storage               | Storing messages in the CAN RAM                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| Number of messages         | <ul> <li>32 message buffers per channel</li> <li>Each message buffer can be set to be either a transmit message buffer or a receive message buffer.</li> </ul>                                                                                                                                                                                                                                                              |  |  |
| Message reception          | <ul> <li>Unique ID can be set to each message buffer.</li> <li>Mask setting of four patterns is possible for each channel.</li> <li>A receive completion interrupt is generated each time a message is received and stored in a message buffer.</li> <li>Two or more receive message buffers can be used as a FIFO receive buffer (multi-buffer receive block function).</li> <li>Receive history list function</li> </ul>  |  |  |
| Message transmission       | <ul> <li>Unique ID can be set to each message buffer.</li> <li>Transmit completion interrupt for each message buffer</li> <li>Message buffer number 0 to 7 specified as the transmit message buffer can be set for automatic block transfer. Message transmission interval is programmable (automatic block transmission function (hereafter referred to as "ABT")).</li> <li>Transmission history list function</li> </ul> |  |  |
| Remote frame processing    | Remote frame processing by transmit message buffer                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| Time stamp function        | <ul> <li>The time stamp function can be set for a message reception when a 16-bit timer is used in combination.</li> <li>Time stamp capture trigger can be selected (SOF or EOF in a CAN message frame can be detected.).</li> <li>The time stamp function can be set for a transmit message.</li> </ul>                                                                                                                    |  |  |
| Diagnostic function        | <ul> <li>Readable error counters</li> <li>"Valid protocol operation flag" for verification of bus connections</li> <li>Receive-only mode</li> <li>Single-shot mode</li> <li>CAN protocol error type decoding</li> <li>Self-test mode</li> </ul>                                                                                                                                                                             |  |  |
| Release from bus-off state | <ul><li>Forced release from bus-off (by ignoring timing constraint) possible by software.</li><li>No automatic release from bus-off (software must re-enable).</li></ul>                                                                                                                                                                                                                                                    |  |  |
| Power save mode            | <ul><li>CAN Sleep mode (can be woken up by CAN bus)</li><li>CAN Stop mode (cannot be woken up by CAN bus)</li></ul>                                                                                                                                                                                                                                                                                                         |  |  |



## 14.1.2 Configuration

The CAN Controller is composed of the following four blocks.

- NPB interface This functional block provides an NPB (Peripheral I/O Bus) interface and means of transmitting and receiving signals between the CAN module and the host CPU.
- MCM (Memory Control Module) This functional block controls access to the CAN protocol layer and to the CAN RAM within the CAN module.
- CAN protocol layer This functional block is involved in the operation of the CAN protocol and its related settings.
- CAN RAM This is the CAN memory functional block, which is used to store message IDs, message data, etc.



Figure 14-1 Block diagram of CAN module



## 14.2 CAN Protocol

CAN (Controller Area Network) is a high-speed multiplex communication protocol for real-time communication in automotive applications (class C). CAN is prescribed by ISO 11898. For details, refer to the ISO 11898 specifications.

The CAN specification is generally divided into two layers: a physical layer and a data link layer. In turn, the data link layer includes logical link and medium access control. The composition of these layers is illustrated below.

| Higher |                                    | Logical link control (LLC)  | Acceptance filtering                                    |
|--------|------------------------------------|-----------------------------|---------------------------------------------------------|
| Î      |                                    |                             | Overload report                                         |
|        | Data link<br>laver <sup>Note</sup> |                             | Recovery management                                     |
|        |                                    | Medium access control (MAC) | Data capsuled/not capsuled                              |
|        |                                    |                             | <ul> <li>Frame coding (stuffing/no stuffing)</li> </ul> |
|        |                                    |                             | Medium access management                                |
|        |                                    |                             | Error detection                                         |
|        |                                    |                             | Error report                                            |
|        |                                    |                             | Acknowledgement                                         |
|        |                                    |                             | Seriated/not seriated                                   |
| Lower  | wer Physical layer                 |                             | Prescription of signal level and bit description        |

#### Figure 14-2 Composition of layers

Note CAN Controller specification

## 14.2.1 Frame format

#### (1) Standard format frame

• The standard format frame uses 11-bit identifiers, which means that it can handle up to 2,048 messages.

#### (2) Extended format frame

- The extended format frame uses 29-bit (11 bits + 18 bits) identifiers, which increases the number of messages that can be handled to  $2,048 \times 2^{18}$  messages.
- An extended format frame is set when "recessive level" (CMOS level of "1") is set for both the SRR and IDE bits in the arbitration field.



#### 14.2.2 Frame types

The following four types of frames are used in the CAN protocol.

#### Table 14-2 Frame types

| Frame Type     | Description                                             |
|----------------|---------------------------------------------------------|
| Data frame     | Frame used to transmit data                             |
| Remote frame   | Frame used to request a data frame                      |
| Error frame    | Frame used to report error detection                    |
| Overload frame | Frame used to delay the next data frame or remote frame |

#### (1) Bus value

The bus values are divided into dominant and recessive.

- Dominant level is indicated by logical 0.
- Recessive level is indicated by logical 1.
- When a dominant level and a recessive level are transmitted simultaneously, the bus value becomes dominant level.

#### 14.2.3 Data frame and remote frame

#### (1) Data frame

A data frame is composed of seven fields.





Note D: Dominant = 0 R: Recessive = 1



#### (2) Remote frame

A remote frame is composed of six fields.





- **Note 1.** The data field is not transferred even if the control field's data length code is not "0000<sub>B</sub>".
  - 2. D: Dominant = 0 R: Recessive = 1

#### (3) Description of fields

#### (a) Start of frame (SOF)

The start of frame field is located at the start of a data frame or remote frame.



#### Figure 14-5 Start of frame (SOF)

- Note D: Dominant = 0 R: Recessive = 1
  - If dominant level is detected in the bus idle state, a hard-synchronization is performed (the current TQ is assigned to be the SYNC segment).
  - If dominant level is sampled at the sample point following such a hardsynchronization, the bit is assigned to be a SOF. If recessive level is detected, the protocol layer returns to the bus idle state and regards the preceding dominant pulse as a disturbance only. No error frame is generated in such case.



#### (b) Arbitration field

The arbitration field is used to set the priority, data frame/remote frame, and frame format.



Caution 1. ID28 to ID18 are identifiers.

2. An identifier is transmitted MSB first.

Note D: Dominant = 0 R: Recessive = 1

#### Table 14-3 RTR frame settings

| Frame type   | RTR bit |
|--------------|---------|
| Data frame   | 0 (D)   |
| Remote frame | 1 (R)   |

#### Table 14-4 Frame format setting (IDE bit) and number of identifier (ID) bits

| Frame format         | SRR bit | IDE bit | Number of bits |
|----------------------|---------|---------|----------------|
| Standard format mode | None    | 0 (D)   | 11 bits        |
| Extended format mode | 1 (R)   | 1 (R)   | 29 bits        |



#### (c) Control field

The control field sets "DLC" as the number of data bytes in the data field (DLC = 0 to 8).



Figure 14-8 Control field

Note D: Dominant = 0 R: Recessive = 1

In a standard format frame, the control field's IDE bit is the same as the r1 bit.

#### Table 14-5Data length setting

| Data length code |                  |      | Data byte count |                                                 |
|------------------|------------------|------|-----------------|-------------------------------------------------|
| DLC3             | DLC2             | DLC1 | DLC0            |                                                 |
| 0                | 0                | 0    | 0               | 0 bytes                                         |
| 0                | 0                | 0    | 1               | 1 byte                                          |
| 0                | 0                | 1    | 0               | 2 bytes                                         |
| 0                | 0                | 1    | 1               | 3 bytes                                         |
| 0                | 1                | 0    | 0               | 4 bytes                                         |
| 0                | 1                | 0    | 1               | 5 bytes                                         |
| 0                | 1                | 1    | 0               | 6 bytes                                         |
| 0                | 1                | 1    | 1               | 7 bytes                                         |
| 1                | 0                | 0    | 0               | 8 bytes                                         |
|                  | Other than above |      |                 | 8 bytes regardless of the value of DLC3 to DLC0 |

Caution In the remote frame, there is no data field even if the data length code is not  $0000_{\text{B}}$ .



#### (d) Data field

The data field contains the amount of data (byte units) set by the control field. Up to 8 units of data can be set.





```
Note D: Dominant = 0
R: Recessive = 1
```

#### (e) CRC field

The CRC field is a 16-bit field that is used to check for errors in transmit data.

| (Data field or control field) | CRC field    | ─ <del>&gt;</del>   <del>⊲</del> ─(ACK field) |
|-------------------------------|--------------|-----------------------------------------------|
| R ———                         |              |                                               |
| D                             | CRC sequence |                                               |
|                               |              | delimiter<br>1 bit)                           |

Figure 14-10 CRC field

Note D: Dominant = 0 R: Recessive = 1

• The polynomial P(X) used to generate the 15-bit CRC sequence is expressed as follows.

 $\mathsf{P}(\mathsf{X}) = \mathsf{X}^{15} + \mathsf{X}^{14} + \mathsf{X}^{10} + \mathsf{X}^8 + \mathsf{X}^7 + \mathsf{X}^4 + \mathsf{X}^3 + 1$ 

- Transmitting node: Transmits the CRC sequence calculated from the data (before bit stuffing) in the start of frame, arbitration field, control field, and data field.
   Receiving node: Compares the CRC sequence calculated using
- Receiving node: Compares the CRC sequence calculated using data bits that exclude the stuffing bits in the receive data with the CRC sequence in the CRC field. If the two CRC sequences do not match, the node issues an error frame.



#### (f) ACK field

The ACK field is used to acknowledge normal reception.



#### Figure 14-11 ACK field

Note D: Dominant = 0 R: Recessive = 1

- If no CRC error is detected, the receiving node sets the ACK slot to the dominant level.
- The transmitting node outputs two recessive-level bits.

#### (g) End of frame (EOF)

The end of frame field indicates the end of data frame/remote frame.



Figure 14-12 End of frame (EOF)

Note D: Dominant = 0 R: Recessive = 1



#### (h) Interframe space

The interframe space is inserted after a data frame, remote frame, error frame, or overload frame to separate one frame from the next.

• The bus state differs depending on the error status.

#### - Error active node

The interframe space consists of a 3-bit intermission field and a bus idle field.



Figure 14-13 Interframe space (error active node)

Note 1. Bus idle: State in which the bus is not used by any node.

2. D: Dominant = 0 R: Recessive = 1

## - Error passive node

The interframe space consists of an intermission field, a suspend transmission field, and a bus idle field.

|        | (Frame) |                       | Interframe space                 |                           | (Frame) |
|--------|---------|-----------------------|----------------------------------|---------------------------|---------|
| R<br>D |         | ermission<br>(3 bits) | Suspend transmission<br>(8 bits) | Bus idle<br>(0 to ∞ bits) |         |

#### Figure 14-14 Interframe space (error passive node)

Note 1. Bus idle: Suspend transmission: State in which the bus is not used by any node. Sequence of 8 recessive-level bits transmitted from the node in the error passive status.

2. D: Dominant = 0 R: Recessive = 1

Usually, the intermission field is 3 bits. If the transmitting node detects a dominant level at the third bit of the intermission field, however, it executes transmission.

· Operation in error status

Table 14-6 Operation in error status

| Error status  | Operation                                                                  |
|---------------|----------------------------------------------------------------------------|
| Error active  | A node in this status can transmit immediately after a 3-bit intermission. |
| Error passive | A node in this status can transmit 8 bits after the intermission.          |



## 14.2.4 Error frame

An error frame is output by a node that has detected an error.



Figure 14-15 Error frame

Note D: Dominant = 0 R: Recessive = 1

| Table 14-7 | Definition of error frame fields |
|------------|----------------------------------|
|            |                                  |

| No. | Name                               | Bit<br>count | Definition                                                                                                                                                                                 |  |
|-----|------------------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| <1> | Error flag 1                       | 6            | Error active node:Outputs 6 dominant-level bits consecutively.Error passive node:Outputs 6 recessive-level bits consecutively.                                                             |  |
|     |                                    |              | If another node outputs a dominant level while one node is outputting<br>a passive error flag, the passive error flag is not cleared until the<br>same level is detected 6 bits in a row.  |  |
| <2> | Error flag 2                       | 0 to 6       | Nodes receiving error flag 1 detect bit stuff errors and issues this error flag.                                                                                                           |  |
| <3> | Error delimiter                    | 8            | Outputs 8 recessive-level bits consecutively.<br>If a dominant level is detected at the 8th bit, an overload frame is<br>transmitted from the next bit.                                    |  |
| <4> | Error bit                          | _            | The bit at which the error was detected.<br>The error flag is output from the bit next to the error bit.<br>In the case of a CRC error, this bit is output following the ACK<br>delimiter. |  |
| <5> | Interframe<br>space/overload frame | _            | An interframe space or overload frame starts from here.                                                                                                                                    |  |



## 14.2.5 Overload frame

An overload frame is transmitted under the following conditions.

- When the receiving node has not completed the reception operation
- If a dominant level is detected at the first two bits during intermission
- If a dominant level is detected at the last bit (7th bit) of the end of frame or at the last bit (8th bit) of the error delimiter/overload delimiter
- **Note** The CAN is internally fast enough to process all received frames not generating overload frames.



Figure 14-16 Overload frame

Note D: Dominant = 0 R: Recessive = 1

#### Table 14-8 Definition of overload frame fields

| No  | Name                               | Bit count | Definition                                                                                                                                              |
|-----|------------------------------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| <1> | Overload flag                      | 6         | Outputs 6 dominant-level bits consecutively.                                                                                                            |
| <2> | Overload flag from other node      | 0 to 6    | The node that received an overload flag in the interframe space outputs an overload flag.                                                               |
| <3> | Overload delimiter                 | 8         | Outputs 8 recessive-level bits consecutively.<br>If a dominant level is detected at the 8th bit, an overload<br>frame is transmitted from the next bit. |
| <4> | Frame                              | -         | Output following an end of frame, error delimiter, or overload delimiter.                                                                               |
| <5> | Interframe space/overload<br>frame | _         | An interframe space or overload frame starts from here.                                                                                                 |



## 14.3 Functions

## 14.3.1 Determining bus priority

#### (1) When a node starts transmission:

• During bus idle, the node that output data first transmits the data.

#### (2) When more than one node starts transmission:

- The node that consecutively outputs the dominant level for the longest from the first bit of the arbitration field has the bus priority (if a dominant level and a recessive level are simultaneously transmitted, the dominant level is taken as the bus value).
- The transmitting node compares its output arbitration field and the data level on the bus.

#### Table 14-9 Determining bus priority

| Level match    | Continuous transmission                                                                            |
|----------------|----------------------------------------------------------------------------------------------------|
| Level mismatch | Stops transmission at the bit where mismatch is detected and starts reception at the following bit |

#### (3) Priority of data frame and remote frame

- When a data frame and a remote frame are on the bus, the data frame has priority because its RTR bit, the last bit in the arbitration field, carries a dominant level.
- **Note** If the extended-format data frame and the standard-format remote frame conflict on the bus (if ID28 to ID18 of both of them are the same), the standard-format remote frame takes priority.

#### 14.3.2 Bit stuffing

Bit stuffing is used to establish synchronization by appending 1 bit of invertedlevel data if the same level continues for 5 bits, in order to prevent a burst error.

#### Table 14-10 Bit stuffing

| Transmission | During the transmission of a data frame or remote frame, when the same level continues for 5 bits in the data between the start of frame and the ACK field, 1 inverted-level bit of data is inserted before the following bit. |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reception    | During the reception of a data frame or remote frame, when the same level continues for 5 bits in the data between the start of frame and the ACK field, reception is continued after deleting the next bit.                   |



#### 14.3.3 Multi masters

As the bus priority (a node acquiring transmit functions) is determined by the identifier, any node can be the bus master.

#### 14.3.4 Multi cast

Although there is one transmitting node, two or more nodes can receive the same data at the same time because the same identifier can be set to two or more nodes.

#### 14.3.5 CAN sleep mode/CAN stop mode function

The CAN sleep mode/CAN stop mode function puts the CAN Controller in waiting mode to achieve low power consumption.

The controller is woken up from the CAN sleep mode by bus operation but it is not woken up from the CAN stop mode by bus operation (the CAN stop mode is controlled by CPU access).

## 14.3.6 Error control function

#### (1) Error types

|                | Description of error                                                                                  |                                                   | Detection state                 |                                                                                                                        |  |
|----------------|-------------------------------------------------------------------------------------------------------|---------------------------------------------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------|--|
| Туре           | Detection method                                                                                      | Detection<br>condition                            | Transmission/r<br>eception      | Field/frame                                                                                                            |  |
| Bit error      | Comparison of the output<br>level and level on the bus<br>(except stuff bit)                          | Mismatch of levels                                | Transmitting/<br>receiving node | Bit that is outputting data on<br>the bus at the start of frame to<br>end of frame, error frame and<br>overload frame. |  |
| Stuff<br>error | Check of the receive data at the stuff bit                                                            | 6 consecutive bits of<br>the same output<br>level | Receiving node                  | Start of frame to CRC sequence                                                                                         |  |
| CRC<br>error   | Comparison of the CRC<br>sequence generated from<br>the receive data and the<br>received CRC sequence | Mismatch of CRC                                   | Receiving node                  | CRC field                                                                                                              |  |
| Form<br>error  | Field/frame check of the fixed format                                                                 | Detection of fixed<br>format violation            | Receiving node                  | CRC delimiter<br>ACK field<br>End of frame<br>Error frame<br>Overload frame                                            |  |
| ACK<br>error   | Check of the ACK slot by the transmitting node                                                        | Detection of<br>recessive level in<br>ACK slot    | Transmitting node               | ACK slot                                                                                                               |  |

#### Table 14-11 Error types



#### (2) Output timing of error frame

#### Table 14-12 Output timing of error frame

| Туре                                          | Output timing                                                                        |
|-----------------------------------------------|--------------------------------------------------------------------------------------|
| Bit error, stuff error, form error, ACK error | Error frame output is started at the timing of the bit following the detected error. |
| CEC error                                     | Error frame output is started at the timing of the bit following the ACK delimiter.  |

#### (3) Processing in case of error

The transmission node re-transmits the data frame or remote frame after the error frame. (However, it does not re-transmit the frame in the single-shot mode.)

#### (4) Error state

#### (a) Types of error states

The following three types of error states are defined by the CAN specification:

- Error active
- Error passive
- Bus-off

These types of error states are classified by the values of the TEC7 to TEC0 bits (transmission error counter bits) and the REC6 to REC0 bits (reception error counter bits) as shown in *Table 14-13*.

The present error state is indicated by the CAN module information register (CnINFO).

When each error counter value becomes equal to or greater than the error warning level (96), the TECS0 or RECS0 bit of the CnINFO register is set to 1. In this case, the bus state must be tested because it is considered that the bus has a serious fault. An error counter value of 128 or more indicates an error passive state and the TECS1 or RECS1 bit of the CnINFO register is set to 1.

- If the value of the transmission error counter is greater than or equal to 256 (actually, the transmission error counter does not indicate a value greater than or equal to 256), the bus-off state is reached and the BOFF bit of the CnINFO register is set to 1.
- If only one node is active on the bus at startup (i.e., a particular case such as when the bus is connected only to the local station), ACK is not returned even if data is transmitted. Consequently, re-transmission of the error frame and data is repeated. In the error passive state, however, the transmission error counter is not incremented and the bus-off state is not reached.

#### Table 14-13 Types of error states

**Note** The value of the transmission error counter (TEC) is invalid when the BOFF bit is set to 1. If an error that increments the value of the transmission error counter by +8 while the counter value is in a range of 248 to 255, the counter is not incremented and the bus-off state is assumed.



| Туре          | Operation    | Value of error counter                            | Indication of<br>CnINFO register | Operation specific to error state                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|--------------|---------------------------------------------------|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Error active  | Transmission | 0 to 95                                           | TECS1, TECS0 = 00                | Outputs an active error flag (6 consecutive dominant-level bits) on detection of the error.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|               | Reception    | 0 to 95                                           | RECS1, RECS0 = 00                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|               | Transmission | 96 to 127                                         | TECS1, TECS0 = 01                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|               | Reception    | 96 to 127                                         | RECS1, RECS0 = 01                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Error passive | Transmission | 128 to 255                                        | TECS1, TECS0 = 11                | Outputs a passive error flag (6 consecutive<br>recessive-level bits) on detection of the error.<br>Transmits 8 recessive-level bits, in between<br>transmissions, following an intermission<br>(suspend transmission).                                                                                                                                                                                                                                                                                                              |
|               | Reception    | 128 or more                                       | RECS1, RECS0 = 11                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bus-off       | Transmission | 256 or more<br>(not<br>indicated) <sup>Note</sup> | BOFF = 1,<br>TECS1, TECS0 = 11   | Communication is not possible.<br>Messages are not stored when receiving frames,<br>however, the following operations of <1>, <2>,<br>and <3> are done.<br><1> TSOUT toggles.<br><2> REC is incremented/decremented.<br><3> VALID bit is set.<br>If the CAN module is entered to the initialization<br>mode and then transition request to any<br>operation mode is made, and when 11<br>consecutive recessive-level bits are detected<br>128 times, the error counter is reset to 0 and the<br>error active state can be restored. |

#### (b) Error counter

The error counter counts up when an error has occurred, and counts down upon successful transmission and reception. The error counter is updated immediately after error detection.

#### (c) Occurrence of bit error in intermission

An overload frame is generated.

**Caution** If an error occurs, it is controlled according to the contents of the transmission error counter and reception error counter before the error occurred. The value of the error counter is incremented after the error flag has been output.

#### (5) Recovery from bus-off state

When the CAN module is in the bus-off state, the CAN module permanently sets its output signals (CTXDn) to recessive level.

The CAN module recovers from the bus-off state in the following bus-off recovery sequence.

#### 1. A request to enter the CAN initialization mode

# A request to enter a CAN operation mode (a)Recovery operation through normal recovery sequence (b)Forced recovery operation that skips recovery sequence



#### Table 14-14 Error counter

| State                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Transmission error counter<br>(TEC7 to TEC0 bits) | Reception error counter<br>(REC6 to REC0 bits)                                                                                                                                                                                |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Receiving node detects an error (except bit error in the active error flag or overload flag).                                                                                                                                                                                                                                                                                                                                                                 | No change                                         | +1 (when REPS = 0)                                                                                                                                                                                                            |
| Receiving node detects dominant level following error flag of error frame.                                                                                                                                                                                                                                                                                                                                                                                    | No change                                         | +8 (when REPS = 0)                                                                                                                                                                                                            |
| <ul> <li>Transmitting node transmits an error flag.</li> <li>[As exceptions, the error counter does not change in the following cases.]</li> <li>&lt;1&gt; ACK error is detected in error passive state and dominant level is not detected while the passive error flag is being output.</li> <li>&lt;2&gt; A stuff error is detected in an arbitration field that transmitted a recessive level as a stuff bit, but a dominant level is detected.</li> </ul> | +8                                                | No change                                                                                                                                                                                                                     |
| Bit error detection while active error flag or<br>overload flag is being output (error-active<br>transmitting node)                                                                                                                                                                                                                                                                                                                                           | +8                                                | No change                                                                                                                                                                                                                     |
| Bit error detection while active error flag or<br>overload flag is being output (error-active<br>receiving node)                                                                                                                                                                                                                                                                                                                                              | No change                                         | +8 (REPS bit = 0)                                                                                                                                                                                                             |
| When the node detects 14 consecutive<br>dominant-level bits from the beginning of the<br>active error flag or overload flag, and then<br>subsequently detects 8 consecutive dominant-<br>level bits.<br>When the node detects 8 consecutive dominant<br>levels after a passive error flag                                                                                                                                                                     | +8 (transmitting)                                 | +8<br>(during reception, when<br>REPS = 0)                                                                                                                                                                                    |
| When the transmitting node has completed transmission without error $(\pm 0 \text{ if error counter} = 0)$                                                                                                                                                                                                                                                                                                                                                    | -1                                                | No change                                                                                                                                                                                                                     |
| When the receiving node has completed reception without error                                                                                                                                                                                                                                                                                                                                                                                                 | No change                                         | <ul> <li>-1         <ul> <li>(1 ≤ REC6 to REC0 ≤ 127, when REPS = 0)</li> <li>±0                 (REC6 to REC0 = 0, when REPS = 0)</li> <li>Value of 119 to 127 is set                 (when REPS = 1)</li> </ul> </li> </ul> |

#### (a) Recovery from bus-off state through normal recovery sequence

The CAN module first issues a request to enter the initialization mode (refer too timing <1> in *Figure 14-17 on page 387*). This request will be immediately acknowledged, and the OPMODE bits of the CnCTRL. register are cleared to  $000_B$ . Processing such as analyzing the fault that has caused the bus-off state, re-defining the CAN module and message buffer using application software, or stopping the operation of the CAN module can be performed by clearing the GOM bit to 0.

Next, the module requests to change the mode from the initialization mode to an operation mode (refer to timing <2> in *Figure 14-17 on page 387*). This starts an operation to recover the CAN module from the bus-off state. The conditions under which the module can recover from the bus-off state are defined by the CAN protocol ISO 11898, and it is necessary to detect 11 consecutive recessive-level bits 128 times. At this time, the request to change the mode to an operation mode is held pending until the recovery conditions

RENESAS

are satisfied. When the recovery conditions are satisfied (refer to timing <3> in *Figure 14-17 on page 387*), the CAN module can enter the operation mode it has requested. Until the CAN module enters this operation mode, it stays in the initialization mode. Completion to be requested operation mode can be confirmed by reading the OPMODE bits of the CnCTRL register.

During the bus-off period and bus-off recovery sequence, the BOFF bit of the CnINFO register stays set (to 1). In the bus-off recovery sequence, the reception error counter (REC[6:0]) counts the number of times 11 consecutive recessive-level bits have been detected on the bus. Therefore, the recovery state can be checked by reading REC[6:0].



**Caution** In the bus-off recovery sequence, REC[6:0] counts up (+1) each time 11 consecutive recessive-level bits have been detected. Even during the bus-off period, the CAN module can enter the CAN sleep mode or CAN stop mode. To start the bus-off recovery sequence, it is necessary to transit to the initialization mode once. However, when the CAN module is in either CAN sleep mode or CAN stop mode, transition request to the initialization mode is not accepted, thus you have to release the CAN sleep mode first. In this case, as soon as the CAN sleep mode is released, the bus-off recovery sequence starts and no transition to initialization mode is necessary. If the can module detects a dominant edge on the CAN bus while in sleep mode even during bus-off, the sleep mode will be left and the bus-off recovery sequence will start.



Figure 14-17 Recovery from bus-off state through normal recovery sequence

#### (b) Forced recovery operation that skips bus-off recovery sequence

The CAN module can be forcibly released from the bus-off state, regardless of the bus state, by skipping the bus-off recovery sequence. Here is the procedure.

First, the CAN module requests to enter the initialization mode. For the operation and points to be noted at this time, *"Recovery from bus-off state through normal recovery sequence" on page 385*.

Next, the module requests to enter an operation mode. At the same time, the CCERC bit of the CnCTRL register must be set to 1.

As a result, the bus-off recovery sequence defined by the CAN protocol ISO 11898 is skipped, and the module immediately enters the operation mode. In this case, the module is connected to the CAN bus after it has monitored 11 consecutive recessive-level bits. For details, refer to the processing in *Figure 14-55 on page 500*.

RENESAS

**Caution** This function is not defined by the CAN protocol ISO 11898. When using this function, thoroughly evaluate its effect on the network system.

# (6) Initializing CAN module error counter register (CnERC) in initialization mode

If it is necessary to initialize the CAN module error counter register (CnERC) and CAN module information register (CnINFO) for debugging or evaluating a program, they can be initialized to the default value by setting the CCERC bit of the CnCTRL register in the initialization mode. When initialization has been completed, the CCERC bit is automatically cleared to 0.

- **Caution 1.** This function is enabled only in the initialization mode. Even if the CCERC bit is set to 1 in a CAN operation mode, the CnERC and CnINFO registers are not initialized.
  - 2. The CCERC bit can be set at the same time as the request to enter a CAN operation mode.



## 14.3.7 Baud rate control function

#### (1) Prescaler

The CAN controller has a prescaler that divides the clock ( $f_{CAN}$ ) supplied to CAN. This prescaler generates a CAN protocol layer basic system clock ( $f_{TQ}$ ) derived from the CAN module system clock ( $f_{CANMOD}$ ), and divided by 1 to 256 ("CnBRP - CANn module bit rate prescaler register" on page 420).

#### (2) Data bit time (8 to 25 time quanta)

One data bit time is defined as shown in *Figure 14-18 on page 389*.

The CAN Controller sets time segment 1, time segment 2, and reSynchronization Jump Width (SJW) of data bit time, as shown in *Figure 14-18*. Time segment 1 is equivalent to the total of the propagation (prop) segment and phase segment 1 that are defined by the CAN protocol specification. Time segment 2 is equivalent to phase segment 2.





| Table 14-15 | Segment setting |
|-------------|-----------------|
|-------------|-----------------|

| Segment name                          | Settable range | Notes on setting to conform to CAN specification                                                                                                                                                                                                             |
|---------------------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Time segment 1 (TSEG1)                | 2TQ to 15TQ    | -                                                                                                                                                                                                                                                            |
| Time segment 2 (TSEG2)                | 1TQ to 8TQ     | IPT of the CAN controller is 0TQ. To conform to the CAN protocol specification, therefore, a length less or equal to phase segment 1 must be set here. This means that the length of time segment 1 minus 1TQ is the settable upper limit of time segment 2. |
| Resynchronization Jump<br>Width (SJW) | 1TQ to 4TQ     | The length of time segment 1 minus 1TQ or 4 TQ, whichever is smaller.                                                                                                                                                                                        |

- Note 1. IPT: Information Processing Time
  - 2. TQ: Time Quanta

Reference: The CAN protocol specification defines the segments constituting the data bit time as shown in *Figure 14-19*.





| Figure 14-19 | Configuration of data bit ti | me defined by CAN specification |
|--------------|------------------------------|---------------------------------|
|--------------|------------------------------|---------------------------------|

| Table 14-16 | Configuration of data bit time defined by CAN specification |
|-------------|-------------------------------------------------------------|
|-------------|-------------------------------------------------------------|

| Segment name                                              | Settable range                                                                  | Notes on setting to conform to CAN specification                                                                                                                  |
|-----------------------------------------------------------|---------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Sync segment<br>(Synchronization segment)                 | 1                                                                               | This segment starts at the edge where the level changes from recessive to dominant when hardware synchronization is established.                                  |
| Prop segment                                              | Programmable to 1 to 8 or more                                                  | This segment absorbs the delay of the output buffer, CAN bus, and input buffer.                                                                                   |
| Phase segment 1                                           | Programmable to 1 to 8                                                          | The length of this segment is set so that ACK is                                                                                                                  |
| Phase segment 2 Phase segment 1 or IPT, whichever greater |                                                                                 | returned before the start of phase segment 1.<br>Time of prop segment $\geq$ (Delay of output buffer) +<br>2 × (Delay of CAN bus) + (Delay of input buffer)       |
|                                                           |                                                                                 | This segment compensates for an error of data bit<br>time.<br>The longer this segment, the wider the permissible<br>range but the slower the communication speed. |
| SJW                                                       | Programmable from 1TQ to<br>length of segment 1 or 4TQ,<br>whichever is smaller | This width sets the upper limit of expansion or contraction of the phase segment during resynchronization.                                                        |

Note IPT: Information Processing Time



#### (3) Synchronizing data bit

- The receiving node establishes synchronization by a level change on the bus because it does not have a sync signal.
- The transmitting node transmits data in synchronization with the bit timing of the transmitting node.

#### (a) Hardware synchronization

This synchronization is established when the receiving node detects the start of frame in the interframe space.

 When a falling edge is detected on the bus, that TQ means the sync segment and the next segment is the prop segment. In this case, synchronization is established regardless of SJW.

|         |                 |                 |                    | Start of frame     |  |  |  |
|---------|-----------------|-----------------|--------------------|--------------------|--|--|--|
| CAN bus |                 |                 |                    |                    |  |  |  |
|         | ļ               |                 |                    |                    |  |  |  |
|         | Sync<br>segment | Prop<br>segment | Phase<br>segment 1 | Phase<br>segment 2 |  |  |  |

Figure 14-20 Adjusting synchronization of data bit

#### (b) Resynchronization

Synchronization is established again if a level change is detected on the bus during reception (only if a recessive level was sampled previously).

- The phase error of the edge is given by the relative position of the detected edge and sync segment.
  - <Sign of phase error>
  - 0: If the edge is within the sync segment

Positive: If the edge is before the sample point (phase error)

Negative: If the edge is after the sample point (phase error)

If phase error is positive: Phase segment 1 is lengthened by specified SJW.

If phase error is negative: Phase segment 2 is shortened by specified SJW.

• The sample point of the data of the receiving node moves relatively due to the "discrepancy" in the baud rate between the transmitting node and receiving node.







## 14.4 Connection with Target System

The CAN module has to be connected to the CAN bus using an external transceiver.



Figure 14-22 Connection to CAN bus



## 14.5 Internal Registers of CAN Controller

#### 14.5.1 CAN module register and message buffer addresses

In this chapter all register and message buffer addresses are defined as address offsets to different base addresses.

Since all registers are accessed via the programmable peripheral area the bottom address is defined by the BPC register (refer to *"Programmable peripheral I/O area"* on page 90 or to *"Programmable peripheral I/O area"* (*PPA*)*"* on page 197).

The addresses given in the following tables are offsets to the programmable peripheral area base address PBA.

The recommended setting of BPC is  $A100_{H}$ . This setting would define the programmable peripheral area base address

PBA = 0840 0000<sub>H</sub>

Table 14-17 lists all base addresses used throughout this chapter.

| Base address name | Base address of      | Address                | Address for BPC =A100 <sub>H</sub> |
|-------------------|----------------------|------------------------|------------------------------------|
| CORBaseAddr       | CAN0 registers       | PBA + 000 <sub>H</sub> | 0840 0000 <sub>H</sub>             |
| C0MBaseAddr       | CAN0 message buffers | PBA + 100 <sub>H</sub> | 0840 0100 <sub>H</sub>             |
| C1RBaseAddr       | CAN1 registers       | PBA + 600 <sub>H</sub> | 0840 0600 <sub>H</sub>             |
| C1MBaseAddr       | CAN1 message buffers | PBA + 700 <sub>H</sub> | 0840 0700 <sub>H</sub>             |

Table 14-17 CAN module base addresses

In the following <CnRBaseAddr> respectively <CnMBaseAddr> are used for the base address names for CAN channel n.



## 14.5.2 CAN Controller configuration

| Table 14-18 | List of CAN Controller registers |
|-------------|----------------------------------|
|-------------|----------------------------------|

| Item                  | Register Name                                                              |  |  |  |  |  |
|-----------------------|----------------------------------------------------------------------------|--|--|--|--|--|
| CANn global registers | CANn global control register (CnGMCTRL)                                    |  |  |  |  |  |
|                       | CANn global clock selection register (CnGMCS)                              |  |  |  |  |  |
|                       | CANn global automatic block transmission control register (CnGMABT)        |  |  |  |  |  |
|                       | CANn global automatic block transmission delay setting register (CnGMABTD) |  |  |  |  |  |
| CANn module registers | CANn module mask 1 register (CnMASK1L, CnMASK1H)                           |  |  |  |  |  |
|                       | CANn module mask 2 register (CnMASK2L, CnMASK2H)                           |  |  |  |  |  |
|                       | CANn module mask3 register (CnMASK3L, CnMASK3H)                            |  |  |  |  |  |
|                       | CANn module mask 4 registers (CnMASK4L, CnMASK4H)                          |  |  |  |  |  |
|                       | CANn module control register (CnCTRL)                                      |  |  |  |  |  |
|                       | CANn module last error information register (CnLEC)                        |  |  |  |  |  |
|                       | CANn module information register (CnINFO)                                  |  |  |  |  |  |
|                       | CANn module error counter register (CnERC)                                 |  |  |  |  |  |
|                       | CANn module interrupt enable register (CnIE)                               |  |  |  |  |  |
|                       | CANn module interrupt status register (CnINTS)                             |  |  |  |  |  |
|                       | CANn module bit rate prescaler register (CnBRP)                            |  |  |  |  |  |
|                       | CANn module bit rate register (CnBTR)                                      |  |  |  |  |  |
|                       | CANn module last in-pointer register (CnLIPT)                              |  |  |  |  |  |
|                       | CANn module receive history list register (CnRGPT)                         |  |  |  |  |  |
|                       | CANn module last out-pointer register (CnLOPT)                             |  |  |  |  |  |
|                       | CANn module transmit history list register (CnTGPT)                        |  |  |  |  |  |
|                       | CANn module time stamp register (CnTS)                                     |  |  |  |  |  |
| CANn message buffer   | CANn message data byte 01 register m (CnMDATA01m)                          |  |  |  |  |  |
| registers             | CANn message data byte 0 register m (CnMDATA0m)                            |  |  |  |  |  |
|                       | CANn message data byte 1 register m (CnMDATA1m)                            |  |  |  |  |  |
|                       | CANn message data byte 23 register m (CnMDATA23m)                          |  |  |  |  |  |
|                       | CANn message data byte 2 register m (CnMDATA2m)                            |  |  |  |  |  |
|                       | CANn message data byte 3 register m (CnMDATA3m)                            |  |  |  |  |  |
|                       | CANn message data byte 45 register m (CnMDATA45m)                          |  |  |  |  |  |
|                       | CANn message data byte 4 register m (CnMDATA4m)                            |  |  |  |  |  |
|                       | CANn message data byte 5 register m (CnMDATA5m)                            |  |  |  |  |  |
|                       | CANn message data byte 67 register m (CnMDATA67m)                          |  |  |  |  |  |
|                       | CANn message data byte 6 register m (CnMDATA6m)                            |  |  |  |  |  |
|                       | CANn message data byte 7 register m (CnMDATA7m)                            |  |  |  |  |  |
|                       | CANn message data length register m (CnMDLCm)                              |  |  |  |  |  |
|                       | CANn message configuration register m (CnMCONFm)                           |  |  |  |  |  |
|                       | CANn message ID register m (CnMIDLm, CnMIDHm)                              |  |  |  |  |  |
|                       | CANn message control register m (CnMCTRLm)                                 |  |  |  |  |  |



## 14.5.3 CAN registers overview

#### (1) CANn global and module registers

The following table lists the address offsets to the CANn register base address: CnRBaseAddr.

| Address          | Register name                                           | Symbol   | R/W | Access |       |        | A (1              |
|------------------|---------------------------------------------------------|----------|-----|--------|-------|--------|-------------------|
| offset           |                                                         |          |     | 1-bit  | 8-bit | 16-bit | After reset       |
| 000 <sub>H</sub> | CANn global control register                            | CnGMCTRL | R/W | _      | -     |        | 0000 <sub>H</sub> |
| 002 <sub>H</sub> | CANn global clock selection register                    | CnGMCS   |     | -      | V     | -      | 0F <sub>H</sub>   |
| 006 <sub>H</sub> | CANn global automatic block transmission register       | CnGMABT  |     | -      | -     | V      | 0000 <sub>H</sub> |
| 008 <sub>H</sub> | CANn global automatic block transmission delay register | CnGMABTD |     | -      | V     | -      | 00 <sub>H</sub>   |
| 040 <sub>H</sub> | CANn module mask 1 register                             | CnMASK1L |     | -      | -     | V      | Undefined         |
| 042 <sub>H</sub> |                                                         | CnMASK1H |     | -      | -     | V      | Undefined         |
| 044 <sub>H</sub> | CANn module mask 2 register                             | CnMASK2L |     | -      | -     | V      | Undefined         |
| 046 <sub>H</sub> |                                                         | CnMASK2H |     | -      | -     | V      | Undefined         |
| 048 <sub>H</sub> | CANn module mask 3 register                             | CnMASK3L |     | -      | -     | V      | Undefined         |
| 04A <sub>H</sub> | -                                                       | CnMASK3H |     | -      | -     | V      | Undefined         |
| 04C <sub>H</sub> | CANn module mask 4 register                             | CnMASK4L |     | -      | -     | V      | Undefined         |
| 04E <sub>H</sub> | -                                                       | CnMASK4H |     | -      | -     | V      | Undefined         |
| 050 <sub>H</sub> | CANn module control register                            | CnCTRL   |     | -      | -     | V      | 0000 <sub>H</sub> |
| 052 <sub>H</sub> | CANn module last error code register                    | CnLEC    |     | -      | V     | -      | 00 <sub>H</sub>   |
| 053 <sub>H</sub> | CANn module information register                        | CnINFO   | R   | -      | V     | -      | 00 <sub>H</sub>   |
| 054 <sub>H</sub> | CANn module error counter register                      | CnERC    |     | -      | -     | V      | 0000 <sub>H</sub> |
| 056 <sub>H</sub> | CANn module interrupt enable register                   | CnIE     | R/W | -      | -     | V      | 0000 <sub>H</sub> |
| 058 <sub>H</sub> | CANn module interrupt status register                   | CnINTS   |     | -      | -     | V      | 0000 <sub>H</sub> |
| 05A <sub>H</sub> | CANn module bit-rate prescaler register                 | CnBRP    |     | -      | V     | -      | FF <sub>H</sub>   |
| 05C <sub>H</sub> | CANn module bit-rate register                           | CnBTR    |     | -      | -     | V      | 370F <sub>H</sub> |
| 05E <sub>H</sub> | CANn module last in-pointer register                    | CnLIPT   | R   | -      | V     | -      | Undefined         |
| 060 <sub>H</sub> | CANn module receive history list register               | CnRGPT   | R/W | -      | -     | V      | xx02 <sub>H</sub> |
| 062 <sub>H</sub> | CANn module last out-pointer register                   | CnLOPT   | R   | -      | V     | -      | Undefined         |
| 064 <sub>H</sub> | CANn module transmit history list register              | CnTGPT   | R/W | -      | -     | V      | xx02 <sub>H</sub> |
| 066 <sub>H</sub> | CANn module time stamp register                         | CnTS     | 1   | -      | -     |        | 0000 <sub>H</sub> |

#### Table 14-19 CANn global and module registers



#### (2) CANn message buffer registers

The addresses in the following table denote the address offsets to the CANn message buffer base address:

CnMBaseAddr.

- **Example** CAN0, message buffer register  $m = 14 = E_H$ , byte 6 C0MDATA614 has the address  $E_H \times 20_H + 6_H + C0MBaseAddr$ 
  - Note The message buffer register number m in the register symbols has 2 digits, for example, COMDATA01 $\underline{m}$  = COMDATA0100 for m = 0.

| Address offset                     | Register name                         | Symbol     | R/W | Access |       |        | Attan wasat                         |
|------------------------------------|---------------------------------------|------------|-----|--------|-------|--------|-------------------------------------|
| Address onset                      |                                       |            |     | 1-bit  | 8-bit | 16-bit | After reset                         |
| mx20 <sub>H</sub> + 0 <sub>H</sub> | CANn message data byte 01 register m  | CnMDATA01m | R/W | -      | -     | V      | Undefined                           |
| mx20 <sub>H</sub> + 0 <sub>H</sub> | CANn message data byte 0 register m   | CnMDATA0m  |     | -      | V     | -      | Undefined                           |
| mx20 <sub>H</sub> + 1 <sub>H</sub> | CANn message data byte 1 register m   | CnMDATA1m  |     | -      | V     | -      | Undefined                           |
| mx20 <sub>H</sub> + 2 <sub>H</sub> | CANn message data byte 23 register m  | CnMDATA23m |     | -      | -     |        | Undefined                           |
| mx20 <sub>H</sub> + 2 <sub>H</sub> | CANn message data byte 2 register m   | CnMDATA2m  |     | -      | V     | -      | Undefined                           |
| mx20 <sub>H</sub> + 3 <sub>H</sub> | CANn message data byte 3 register m   | CnMDATA3m  |     | -      | V     | -      | Undefined                           |
| mx20 <sub>H</sub> + 4 <sub>H</sub> | CANn message data byte 45 register m  | CnMDATA45m |     | -      | -     | V      | Undefined                           |
| mx20 <sub>H</sub> + 4 <sub>H</sub> | CANn message data byte 4 register m   | CnMDATA4m  |     | -      | V     | -      | Undefined                           |
| mx20 <sub>H</sub> + 5 <sub>H</sub> | CANn message data byte 5 register m   | CnMDATA5m  |     | -      | V     | -      | Undefined                           |
| mx20 <sub>H</sub> + 6 <sub>H</sub> | CANn message data byte 67 register m  | CnMDATA67m |     | -      | -     | V      | Undefined                           |
| mx20 <sub>H</sub> + 6 <sub>H</sub> | CANn message data byte 6 register m   | CnMDATA6m  |     | -      | V     | -      | Undefined                           |
| mx20 <sub>H</sub> + 7 <sub>H</sub> | CANn message data byte 7 register m   | CnMDATA7m  |     | -      | V     | -      | Undefined                           |
| mx20 <sub>H</sub> + 8 <sub>H</sub> | CANn message data length register m   | CnMDLCm    |     | -      | V     | -      | 0000 xxxx <sub>B</sub>              |
| mx20 <sub>H</sub> + 9 <sub>H</sub> | CANn message configuration register m | CnMCONFm   |     | -      | V     | -      | Undefined                           |
| mx20 <sub>H</sub> + A <sub>H</sub> | CANn message identifier register m    | CnMIDLm    |     | -      | -     | V      | Undefined                           |
| mx20 <sub>H</sub> + C <sub>H</sub> |                                       | CnMIDHm    |     | -      | -     | V      | Undefined                           |
| mx20 <sub>H</sub> + E <sub>H</sub> | CANn message control register m       | CnMCTRLm   |     | -      | -     | V      | 0x00 0000<br>0000 0000 <sub>B</sub> |

#### Table 14-20 CANn message buffer registers



# 14.5.4 Register bit configuration

| Address<br>offset <sup>a</sup> | Symbol       | Bit 7/15 | Bit 6/14 | Bit 5/13 | Bit 4/12 | Bit 3/11 | Bit 2/10 | Bit 1/9       | Bit 0/8         |
|--------------------------------|--------------|----------|----------|----------|----------|----------|----------|---------------|-----------------|
| 00 <sub>H</sub>                | CnGMCTRL (W) | 0        | 0        | 0        | 0        | 0        | 0        | 0             | Clear GOM       |
| 01 <sub>H</sub>                |              | 0        | 0        | 0        | 0        | 0        | 0        | Set EFSD      | Set GOM         |
| 00 <sub>H</sub>                | CnGMCTRL (R) | 0        | 0        | 0        | 0        | 0        | 0        | EFSD          | GOM             |
| 01 <sub>H</sub>                |              | MBON     | 0        | 0        | 0        | 0        | 0        | 0             | 0               |
| 02 <sub>H</sub>                | CnGMCS       | 0        | 0        | 0        | 0        | CCP3     | CCP2     | CCP1          | CCP0            |
| 06 <sub>H</sub>                | CnGMABT (W)  | 0        | 0        | 0        | 0        | 0        | 0        | 0             | Clear<br>ABTTRG |
| 07 <sub>H</sub>                |              | 0        | 0        | 0        | 0        | 0        | 0        | Set<br>ABTCLR | Set<br>ABTTRG   |
| 06 <sub>H</sub>                | CnGMABT (R)  | 0        | 0        | 0        | 0        | 0        | 0        | ABTCLR        | ABTTRG          |
| 07 <sub>H</sub>                | ]            | 0        | 0        | 0        | 0        | 0        | 0        | 0             | 0               |
| 08 <sub>H</sub>                | CnGMABTD     | 0        | 0        | 0        | 0        | ABTD3    | ABTD2    | ABTD1         | ABTD0           |

| Table 14-21 CAN global register b | bit configuration |
|-----------------------------------|-------------------|
|-----------------------------------|-------------------|

a) Base address: <CnRBaseAddr>

| Table 14-22 | CAN module register bit configuration (1/2) |
|-------------|---------------------------------------------|
|-------------|---------------------------------------------|

| Address<br>offset <sup>a</sup> | Symbol     | Bit 7/15     | Bit 6/14        | Bit 5/13       | Bit 4/12         | Bit 3/11         | Bit 2/10         | Bit 1/9          | Bit 0/8          |  |  |
|--------------------------------|------------|--------------|-----------------|----------------|------------------|------------------|------------------|------------------|------------------|--|--|
| 40 <sub>H</sub>                | CnMASK1L   |              |                 |                | CMID7            | to CMID0         |                  |                  |                  |  |  |
| 41 <sub>H</sub>                |            |              | CMID15 to CMID8 |                |                  |                  |                  |                  |                  |  |  |
| 42 <sub>H</sub>                | CnMASK1H   |              |                 |                | CMID23           | to CMID16        |                  |                  |                  |  |  |
| 43 <sub>H</sub>                |            | 0            | 0               | 0              |                  | CN               | IID28 to CMIE    | )24              |                  |  |  |
| 44 <sub>H</sub>                | CnMASK2L   |              |                 |                | CMID7            | to CMID0         |                  |                  |                  |  |  |
| 45 <sub>H</sub>                |            |              |                 |                | CMID15           | 5 to CMID8       |                  |                  |                  |  |  |
| 46 <sub>H</sub>                | CnMASK2H   |              |                 |                | CMID23           | to CMID16        |                  |                  |                  |  |  |
| 47 <sub>H</sub>                |            | 0            | 0               | 0              |                  | CN               | IID28 to CMIE    | )24              |                  |  |  |
| 48 <sub>H</sub>                | CnMASK3L   |              |                 |                | CMID7            | to CMID0         |                  |                  |                  |  |  |
| 49 <sub>H</sub>                |            |              |                 |                | CMID15           | 5 to CMID8       |                  |                  |                  |  |  |
| 4A <sub>H</sub>                | CnMASK3H   |              |                 |                | CMID23           | to CMID16        |                  |                  |                  |  |  |
| 4B <sub>H</sub>                |            | 0            | 0               | 0              |                  | CN               | IID28 to CMIE    | 024              |                  |  |  |
| 4C <sub>H</sub>                | CnMASK4L   |              |                 |                | CMID7            | to CMID0         |                  |                  |                  |  |  |
| 4D <sub>H</sub>                |            |              |                 |                | CMID15           | 5 to CMID8       |                  |                  |                  |  |  |
| 4E <sub>H</sub>                | CnMASK4H   |              |                 |                | CMID23           | to CMID16        |                  |                  |                  |  |  |
| 4F <sub>H</sub>                |            | 0            | 0               | 0              |                  | CN               | IID28 to CMIE    | 024              |                  |  |  |
| 50 <sub>H</sub>                | CnCTRL (W) | 0            | Clear AL        | Clear<br>VALID | Clear<br>PSMODE1 | Clear<br>PSMODE0 | Clear<br>OPMODE2 | Clear<br>OPMODE1 | Clear<br>OPMODE0 |  |  |
| 51 <sub>H</sub>                |            | Set<br>CCERC | Set<br>AL       | 0              | Set<br>PSMODE1   | Set<br>PSMODE0   | Set<br>OPMODE2   | Set<br>OPMODE1   | Set<br>OPMODE0   |  |  |
| 50 <sub>H</sub>                | CnCTRL (R) | CCERC        | AL              | VALID          | PS<br>MODE1      | PS<br>MODE0      | OP<br>MODE2      | OP<br>MODE1      | OP<br>MODE0      |  |  |
| 51 <sub>H</sub>                |            | 0            | 0               | 0              | 0                | 0                | 0                | RSTAT            | TSTAT            |  |  |



| Address<br>offset <sup>a</sup>     | Symbol     | Bit 7/15 | Bit 6/14 | Bit 5/13        | Bit 4/12        | Bit 3/11        | Bit 2/10         | Bit 1/9         | Bit 0/8         |  |
|------------------------------------|------------|----------|----------|-----------------|-----------------|-----------------|------------------|-----------------|-----------------|--|
| 52 <sub>H</sub>                    | CnLEC (W)  | 0        | 0        | 0               | 0               | 0               | 0                | 0               | 0               |  |
| 52 <sub>H</sub>                    | CnLEC (R)  | 0        | 0        | 0               | 0               | 0               | LEC2             | LEC1            | LEC0            |  |
| 53 <sub>H</sub>                    | CnINFO     | 0        | 0        | 0               | BOFF            | TECS1           | TECS0            | RECS1           | RECS0           |  |
| 54 <sub>H</sub>                    | CnERC      |          | •        | •               | TEC7            | to TEC0         | •                | •               |                 |  |
| 55 <sub>H</sub>                    |            | -        |          |                 | REC7            | to REC0         |                  |                 |                 |  |
| 56 <sub>H</sub>                    | CnIE (W)   | 0        | 0        | Clear<br>CIE5   | Clear<br>CIE4   | Clear<br>CIE3   | Clear<br>CIE2    | Clear<br>CIE1   | Clear<br>CIE0   |  |
| 57 <sub>H</sub>                    |            | 0        | 0        | Set CIE5        | Set CIE4        | Set CIE3        | Set CIE2         | Set CIE1        | Set CIEC        |  |
| 56 <sub>H</sub>                    | CnIE (R)   | 0        | 0        | CIE5            | CIE4            | CIE3            | CIE2             | CIE1            | CIE0            |  |
| 57 <sub>H</sub>                    |            | 0        | 0        | 0               | 0               | 0               | 0                | 0               | 0               |  |
| 58 <sub>H</sub>                    | CnINTS (W) | 0        | 0        | Clear<br>CINTS5 | Clear<br>CINTS4 | Clear<br>CINTS3 | Clear<br>CINTS2  | Clear<br>CINTS1 | Clear<br>CINTS0 |  |
| 59 <sub>H</sub>                    |            | 0        | 0        | 0               | 0               | 0               | 0                | 0               | 0               |  |
| 58 <sub>H</sub>                    | CnINTS (R) | 0        | 0        | CINTS5          | CINTS4          | CINTS3          | CINTS2           | CINTS1          | CINTSO          |  |
| 59 <sub>H</sub>                    |            | 0        | 0        | 0               | 0               | 0               | 0                | 0               | 0               |  |
| 5A <sub>H</sub>                    | CnBRP      |          |          |                 | TQPRS7          | to TQPRS0       |                  |                 |                 |  |
| 5C <sub>H</sub>                    | CnBTR      | 0        | 0        | 0               | 0               |                 | TSEG13 t         | o TSEG10        |                 |  |
| 5D <sub>H</sub>                    | -          | 0        | 0        | SJW1            | , SJW0          | 0               | TSEG22 to TSEG20 |                 |                 |  |
| 5E <sub>H</sub>                    | CnLIPT     |          |          |                 | LIPT7           | to LIPT0        | ļ                |                 |                 |  |
| 60 <sub>H</sub>                    | CnRGPT (W) | 0        | 0        | 0               | 0               | 0               | 0                | 0               | Clear<br>ROVF   |  |
| 61 <sub>H</sub>                    |            | 0        | 0        | 0               | 0               | 0               | 0                | 0               | 0               |  |
| 60 <sub>H</sub>                    | CnRGPT (R) | 0        | 0        | 0               | 0               | 0               | 0                | RHPM            | ROVF            |  |
| 61 <sub>H</sub>                    |            |          |          |                 | RGPT7           | to RGPT0        |                  |                 |                 |  |
| F62 <sub>H</sub>                   | CnLOPT     |          |          |                 | LOPT7           | to LOPT0        |                  |                 |                 |  |
| 64 <sub>H</sub>                    | CnTGPT (W) | 0        | 0        | 0               | 0               | 0               | 0                | 0               | Clear<br>TOVF   |  |
| 65 <sub>H</sub>                    |            | 0        | 0        | 0               | 0               | 0               | 0                | 0               | 0               |  |
| 64 <sub>H</sub>                    | CnTGPT (R) | 0        | 0        | 0               | 0               | 0               | 0                | THPM            | TOVF            |  |
| 65 <sub>H</sub>                    |            |          |          |                 | TGPT7           | to TGPT0        |                  |                 |                 |  |
| 66 <sub>H</sub>                    | CnTS (W)   | 0        | 0        | 0               | 0               | 0               | Clear<br>TSLOCK  | Clear<br>TSSEL  | Clear<br>TSEN   |  |
| 67 <sub>H</sub>                    | 1          | 0        | 0        | 0               | 0               | 0               | Set<br>TSLOCK    | Set<br>TSSEL    | Set<br>TSEN     |  |
| 66 <sub>H</sub>                    | CnTS (R)   | 0        | 0        | 0               | 0               | 0               | TSLOCK           | TSSEL           | TSEN            |  |
| 67 <sub>H</sub>                    | 1          | 0        | 0        | 0               | 0               | 0               | 0                | 0               | 0               |  |
| 68 <sub>H</sub> to FF <sub>H</sub> | -          |          | I        | Access          | prohibited (i   | reserved for f  | uture use)       | I               | 1               |  |

# Table 14-22 CAN module register bit configuration (2/2)

a) Base address: <CnRBaseAddr>



| Address<br>offset <sup>a</sup> | Symbol          | Bit 7/15 | Bit 6/14              | Bit 5/13 | Bit 4/12     | Bit 3/11     | Bit 2/10    | Bit 1/9      | Bit 0/8      |  |  |
|--------------------------------|-----------------|----------|-----------------------|----------|--------------|--------------|-------------|--------------|--------------|--|--|
| 0 <sub>H</sub>                 | CnMDATA01m      |          | Message data (byte 0) |          |              |              |             |              |              |  |  |
| 1 <sub>H</sub>                 |                 |          | Message data (byte 1) |          |              |              |             |              |              |  |  |
| 0 <sub>H</sub>                 | CnMDATA0m       |          |                       |          | Message d    | ata (byte 0) |             |              |              |  |  |
| 1 <sub>H</sub>                 | CnMDATA1m       |          |                       |          | Message d    | ata (byte 1) |             |              |              |  |  |
| 2 <sub>H</sub>                 | CnMDATA23m      |          |                       |          | Message da   | ata (byte 2) |             |              |              |  |  |
| 3 <sub>H</sub>                 |                 |          |                       |          | Message da   | ata (byte 3) |             |              |              |  |  |
| 2 <sub>H</sub>                 | CnMDATA2m       |          |                       |          | Message d    | ata (byte 2) |             |              |              |  |  |
| 3 <sub>H</sub>                 | CnMDATA3m       |          |                       |          | Message d    | ata (byte 3) |             |              |              |  |  |
| 4H                             | CnMDATA45m      |          |                       |          | Message da   | ata (byte 4) |             |              |              |  |  |
| 5 <sub>H</sub>                 |                 |          |                       |          | Message da   | ata (byte 5) |             |              |              |  |  |
| 4 <sub>H</sub>                 | CnMDATA4m       |          |                       |          | Message d    | ata (byte 4) |             |              |              |  |  |
| 5 <sub>H</sub>                 | CnMDATA5m       |          |                       |          | Message d    | ata (byte 5) |             |              |              |  |  |
| 6 <sub>H</sub>                 | CnMDATA67m      |          |                       |          | Message da   | ata (byte 6) |             |              |              |  |  |
| 7 <sub>H</sub>                 |                 |          |                       |          | Message da   | ata (byte 7) |             |              |              |  |  |
| 6 <sub>H</sub>                 | CnMDATA6m       |          |                       |          | Message d    | ata (byte 6) |             |              |              |  |  |
| 7 <sub>H</sub>                 | CnMDATA7m       |          |                       |          | Message d    | ata (byte 7) |             |              |              |  |  |
| 8 <sub>H</sub>                 | CnMDLCm         |          | (                     | 0        |              | MDLC3        | MDLC2       | MDLC1        | MDLC0        |  |  |
| 9 <sub>H</sub>                 | CnMCONFm        | OWS      | RTR                   | MT2      | MT1          | MT0          | 0           | 0            | MA0          |  |  |
| A <sub>H</sub>                 | CnMIDLm         | ID7      | ID6                   | ID5      | ID4          | ID3          | ID2         | ID1          | ID0          |  |  |
| B <sub>H</sub>                 |                 | ID15     | ID14                  | ID13     | ID12         | ID11         | ID10        | ID9          | ID8          |  |  |
| C <sub>H</sub>                 | CnMIDHm         | ID23     | ID22                  | ID21     | ID20         | ID19         | ID18        | ID17         | ID16         |  |  |
| D <sub>H</sub>                 |                 | IDE      | 0                     | 0        | ID28         | ID27         | ID26        | ID25         | ID24         |  |  |
| E <sub>H</sub>                 | CnMCTRLm<br>(W) | 0        | 0                     | 0        | Clear<br>MOW | Clear<br>IE  | Clear<br>DN | Clear<br>TRQ | Clear<br>RDY |  |  |
| F <sub>H</sub>                 |                 | 0        | 0                     | 0        | 0            | Set IE       | 0           | Set TRQ      | Set RDY      |  |  |
| E <sub>H</sub>                 | CnMCTRLm        | 0        | 0                     | 0        | MOW          | IE           | DN          | TRQ          | RDY          |  |  |
| F <sub>H</sub>                 | (R)             | 0        | 0                     | MUC      | 0            | 0            | 0           | 0            | 0            |  |  |

# Table 14-23 Message buffer register bit configuration

a) Base address: <CnMBaseAddr>

**Note** For calculation of the complete message buffer register addresses refer to *"CAN registers overview" on page 395.* 



# 14.6 Bit Set/Clear Function

The CAN control registers include registers whose bits can be set or cleared via the CPU and via the CAN interface. An operation error occurs if the following registers are written directly. Do not write any values directly via bit manipulation, read/modify/write, or direct writing of target values.

- CANn global control register (CnGMCTRL)
- CANn global automatic block transmission control register (CnGMABT)
- CANn module control register (CnCTRL)
- CANn module interrupt enable register (CnIE)
- CANn module interrupt status register (CnINTS)
- CANn module receive history list register (CnRGPT)
- CANn module transmit history list register (CnTGPT)
- CANn module time stamp register (CnTS)
- CANn message control register (CnMCTRLm)

All the 16 bits in the above registers can be read via the usual method. Use the procedure described in *Figure 14-23* below to set or clear the lower 8 bits in these registers.

Setting or clearing of lower 8 bits in the above registers is performed in combination with the higher 8 bits (refer to the bit status after set/clear operation is specified in *Figure 14-26*). *Figure 14-23* shows how the values of set bits or clear bits relate to set/clear/no change operations in the corresponding register.







# (1) Bit status after bit setting/clearing operations

|    | 15   | 14    | 13    | 12    | 11    | 10    | 9     | 8     | 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0          |
|----|------|-------|-------|-------|-------|-------|-------|-------|------------|------------|------------|------------|------------|------------|------------|------------|
| Se | et 7 | Set 6 | Set 5 | Set 4 | Set 3 | Set 2 | Set 1 | Set 0 | Clear<br>7 | Clear<br>6 | Clear<br>5 | Clear<br>4 | Clear<br>3 | Clear<br>2 | Clear<br>1 | Clear<br>0 |

| Set 0 7 | Clear 0 7 | Status of bit n after bit set/clear operation |
|---------|-----------|-----------------------------------------------|
| 0       | 0         | No change                                     |
| 0       | 1         | 0                                             |
| 1       | 0         | 1                                             |
| 1       | 1         | No change                                     |



# 14.7 Control Registers

# (1) CnGMCTRL - CANn global control register

The CnGMCTRL register is used to control the operation of the CAN module.

Access This register can be read/written in 16-bit units.

Address <CnRBaseAddr> + 000<sub>H</sub>

Initial Value 0000<sub>H</sub>. The register is initialized by any reset.

# (a) CnGMCTRL read

| 15   | 14 | 13 | 12 | 11 | 10 | 9    | 8   |
|------|----|----|----|----|----|------|-----|
| MBON | 0  | 0  | 0  | 0  | 0  | 0    | 0   |
| 7    | 6  | 5  | 4  | 3  | 2  | 1    | 0   |
| 0    | 0  | 0  | 0  | 0  | 0  | EFSD | GOM |

| MBON | Bit enabling access to message buffer register, transmit/receive history registers                                       |
|------|--------------------------------------------------------------------------------------------------------------------------|
| 0    | Write access and read access to the message buffer register and the transmit/receive history list registers is disabled. |
| 1    | Write access and read access to the message buffer register and the transmit/receive history list registers is enabled.  |

Caution 1. While the MBON bit is cleared (to 0), software access to the message buffers (CnMDATA0m, CnMDATA1m, CnMDATA01m, CnMDATA2m, CnMDATA3m, CnMDATA23m, CnMDATA4m, CnMDATA5m, CnMDATA45m, CnMDATA6m, CnMDATA7m, CnMDATA67m, CnMDLCm, CnMCONFm, CnMIDLm, CnMIDHm, and CnMCTRLm), or registers related to transmit history or receive history (CnLOPT, CnTGPT, CnLIPT, and CnRGPT) is disabled.

- 2. This bit is read-only. Even if 1 is written to the MBON bit while it is 0, the value of the MBON bit does not change, and access to the message buffer registers, or registers related to transmit history or receive history remains disabled.
- Note The MBON bit is cleared (to 0) when the CAN module enters CAN sleep mode/CAN stop mode, or when the GOM bit is cleared (to 0). The MBON bit is set (to 1) when the CAN sleep mode/CAN stop mode is released, or when the GOM bit is set (to 1).



| EFSD | Bit enabling forced shut down                                    |
|------|------------------------------------------------------------------|
| 0    | Forced shut down disabled.                                       |
| 1    | Forced shut down enabled by subsequent clearing of GOM bit to 0. |

- Caution 1. To request forced shut down, the GOM bit must be cleared to 0 in a subsequent, immediately following access after the EFSD bit has been set to 1. If access to another register (including reading the CnGMCTRL register) is executed (even during NMI processing or DMAC operation) without clearing the GOM bit immediately after the EFSD bit has been set to 1, the EFSD bit is forcibly cleared to 0, and the forced shut down request is invalid.
  - 2. EFSD only works, if no continuous DMA transfer is performed.

| GOM | Global operation mode bit              |
|-----|----------------------------------------|
| 0   | CAN module is disabled from operating. |
| 1   | CAN module is enabled to operate.      |

#### Caution The GOM can be cleared only in the initialization mode or immediately after EFSD bit is set (to 1).

#### (b) CnGMCTRL write

| 15 | 14 | 13 | 12 | 11 | 10 | 9           | 8            |
|----|----|----|----|----|----|-------------|--------------|
| 0  | 0  | 0  | 0  | 0  | 0  | Set<br>EFSD | Set<br>GOM   |
| 7  | 6  | 5  | 4  | 3  | 2  | 1           | 0            |
| 0  | 0  | 0  | 0  | 0  | 0  | 0           | Clear<br>GOM |

| Set EFSD | EFSD bit setting       |
|----------|------------------------|
| 0        | No change in EFSD bit. |
| 1        | EFSD bit set to 1.     |

| Set GOM          | Clear GOM | GOM bit setting       |
|------------------|-----------|-----------------------|
| 0                | 1         | GOM bit cleared to 0. |
| 1                | 0         | GOM bit set to 1.     |
| Other than above |           | No change in GOM bit. |

Caution Set the GOM bit and EFSD bit always separately.



# (2) CnGMCS - CANn global clock selection register

The CnGMCS register is used to select the CAN module system clock.

Access This register can be read/written in 8-bit units.

Address <CnRBaseAddr> + 002<sub>H</sub>

Initial Value  $0F_{H}$ . The register is initialized by any reset.

| 7 | 6 | 5 | 4 | 3    | 2    | 1    | 0    |
|---|---|---|---|------|------|------|------|
| 0 | 0 | 0 | 0 | CCP3 | CCP2 | CCP1 | CCP0 |

| CCP3 | CCP2 | CCP1 | CCP1 | CAN module system clock (f <sub>CANMOD</sub> ) |
|------|------|------|------|------------------------------------------------|
| 0    | 0    | 0    | 0    | f <sub>CAN</sub> /1                            |
| 0    | 0    | 0    | 1    | f <sub>CAN</sub> /2                            |
| 0    | 0    | 1    | 0    | f <sub>CAN</sub> /3                            |
| 0    | 0    | 1    | 1    | f <sub>CAN</sub> /4                            |
| 0    | 1    | 0    | 0    | f <sub>CAN</sub> /5                            |
| 0    | 1    | 0    | 1    | f <sub>CAN</sub> /6                            |
| 0    | 1    | 1    | 0    | f <sub>CAN</sub> / <sub>7</sub>                |
| 0    | 1    | 1    | 1    | f <sub>CAN</sub> /8                            |
| 1    | 0    | 0    | 0    | f <sub>CAN</sub> /9                            |
| 1    | 0    | 0    | 1    | f <sub>CAN</sub> /10                           |
| 1    | 0    | 1    | 0    | f <sub>CAN</sub> /11                           |
| 1    | 0    | 1    | 1    | f <sub>CAN</sub> /12                           |
| 1    | 1    | 0    | 0    | f <sub>CAN</sub> /13                           |
| 1    | 1    | 0    | 1    | f <sub>CAN</sub> /14                           |
| 1    | 1    | 1    | 0    | f <sub>CAN</sub> /15                           |
| 1    | 1    | 1    | 1    | f <sub>CAN</sub> /16 (default value)           |

Note  $f_{CAN}$  = clock supplied to CAN



- (3) CnGMABT CANn global automatic block transmission control register The CnGMABT register is used to control the automatic block transmission (ABT) operation.
- Access This register can be read/written in 16-bit units.
- Address <CnRBaseAddr> + 006<sub>H</sub>
- Initial Value 0000<sub>H</sub>. The register is initialized by any reset.

#### (a) CnGMABT read

| 15 | 14 | 13 | 12 | 11 | 10 | 9      | 8      |
|----|----|----|----|----|----|--------|--------|
| 0  | 0  | 0  | 0  | 0  | 0  | 0      | 0      |
| 7  | 6  | 5  | 4  | 3  | 2  | 1      | 0      |
| 0  | 0  | 0  | 0  | 0  | 0  | ABTCLR | ABTTRG |

| ABTCLR | Automatic block transmission engine clear status bit     |
|--------|----------------------------------------------------------|
| 0      | Clearing the automatic transmission engine is completed. |
| 1      | The automatic transmission engine is being cleared.      |

- Note 1. Set the ABTCLR bit to 1 while the ABTTRG bit is cleared to 0. The operation is not guaranteed if the ABTCLR bit is set to 1 while the ABTTRG bit is set to 1.
  - 2. When the automatic block transmission engine is cleared by setting the ABTCLR bit to 1, the ABTCLR bit is automatically cleared to 0 as soon as the requested clearing processing is complete.

| ABTTRG | Automatic block transmission status bit          |
|--------|--------------------------------------------------|
| 0      | Automatic block transmission is stopped.         |
| 1      | Automatic block transmission is under execution. |

- **Caution 1.** Do not set the ABTTRG bit (1) in the initialization mode. If the ABTTRG bit is set in the initialization mode, the operation is not guaranteed after the CAN module has entered the normal operation mode with ABT.
  - 2. Do not set the ABTTRG bit (1) while the CnCTRL.TSTAT bit is set (1). Confirm TSTAT = 0 directly in advance before setting ABTTRG bit.



# (b) CnGMABT write

| 15 | 14 | 13 | 12 | 11 | 10 | 9             | 8               |
|----|----|----|----|----|----|---------------|-----------------|
| 0  | 0  | 0  | 0  | 0  | 0  | Set<br>ABTCLR | Set<br>ABTTRG   |
| 7  | 6  | 5  | 4  | 3  | 2  | 1             | 0               |
| 0  | 0  | 0  | 0  | 0  | 0  | 0             | Clear<br>ABTTRG |

Caution

Before changing the normal operation mode with ABT to the initialization mode, be sure to set the CnGMABT register to the default value  $(0000_{\rm H})$  and confirm the CnGMABT register is surely initialized to the default value  $(0000_{\rm H})$ .

| Set ABTCLR | Automatic block transmission engine clear request bit                                                                                                                                                                   |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | The automatic block transmission engine is in idle status or under operation.                                                                                                                                           |
| 1          | Request to clear the automatic block transmission engine. After the automatic block transmission engine has been cleared, automatic block transmission is started from message buffer 0 by setting the ABTTRG bit to 1. |

| Set ABTTRG       | Clear ABTTRG | Automatic block transmission start bit         |  |  |  |  |
|------------------|--------------|------------------------------------------------|--|--|--|--|
| 0                | 1            | Request to stop automatic block transmission.  |  |  |  |  |
| 1                | 0            | Request to start automatic block transmission. |  |  |  |  |
| Other than above |              | No change in ABTTRG bit.                       |  |  |  |  |



# (4) CnGMABTD - CANn global automatic block transmission delay register

The CnGMABTD register is used to set the interval at which the data of the message buffer assigned to ABT is to be transmitted in the normal operation mode with ABT.

Access This register can be read/written in 8-bit units.

Address <CnRBaseAddr> + 008<sub>H</sub>

Initial Value 00<sub>H</sub>. The register is initialized by any reset.

| 7 | 6 | 5 | 4 | 3     | 2     | 1     | 0     |
|---|---|---|---|-------|-------|-------|-------|
| 0 | 0 | 0 | 0 | ABTD3 | ABTD2 | ABTD1 | ABTD0 |

| ABTD3 | ABTD2      | ABTD1    | ABTD0 | Data frame interval during automatic block transmission in DBT <sup>a</sup> |
|-------|------------|----------|-------|-----------------------------------------------------------------------------|
| 0     | 0          | 0        | 0     | 0 DBT (default value)                                                       |
| 0     | 0          | 0        | 1     | 2 <sup>5</sup> DBT                                                          |
| 0     | 0          | 1        | 0     | 2 <sup>6</sup> DBT                                                          |
| 0     | 0          | 1        | 1     | 2 <sup>7</sup> DBT                                                          |
| 0     | 1          | 0        | 0     | 2 <sup>8</sup> DBT                                                          |
| 0     | 1          | 0        | 1     | 2 <sup>9</sup> DBT                                                          |
| 0     | 1          | 1        | 0     | 2 <sup>10</sup> DBT                                                         |
| 0     | 1          | 1        | 1     | 2 <sup>11</sup> DBT                                                         |
| 1     | 0          | 0        | 0     | 2 <sup>12</sup> DBT                                                         |
|       | Other that | an above |       | Setting prohibited                                                          |

a) Unit: Data bit time (DBT)

Caution

- 1. Do not change the contents of the CnGMABTD register while the ABTTRG bit is set to 1.
- 2. The timing at which the ABT message is actually transmitted onto the CAN bus differs depending on the status of transmission from the other station or how a request to transmit a message other than an ABT message (message buffers 8 to 31) is made.



#### CnMASKaL, CnMASKaH - CANn module mask control register (a = 1 to 4) (5)

The CnMASKaL and CnMASKaH registers are used to extend the number of receivable messages into the same message buffer by masking part of the identifier (ID) comparison of a message and invalidating the ID of the masked part.

## (a) CANn module mask 1 register (CnMASK1L, CnMASK1H)

These registers can be read/written in 16-bit units. Access

| Address | CnMASK1L: | <cnrbaseaddr> + 040<sub>H</sub></cnrbaseaddr> |
|---------|-----------|-----------------------------------------------|
|         | CnMASK1H: | <cnrbaseaddr> + 042<sub>H</sub></cnrbaseaddr> |

Initial Value Undefined.

CnMASK1L

| 15      | 14     | 13     | 12     | 11     | 10     | 9      | 8      |
|---------|--------|--------|--------|--------|--------|--------|--------|
| CMID15  | CMID14 | CMID13 | CMID12 | CMID11 | CMID10 | CMID9  | CMID8  |
| 7       | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| CMID7   | CMID6  | CMID5  | CMID4  | CMID3  | CMID2  | CMID1  | CMID0  |
|         |        |        |        |        |        |        |        |
| CnMASK1 | Н      |        |        |        |        |        |        |
| 15      | 14     | 13     | 12     | 11     | 10     | 9      | 8      |
| 0       | 0      | 0      | CMID28 | CMID27 | CMID26 | CMID25 | CMID24 |
| 7       | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| CMID23  | CMID22 | CMID21 | CMID20 | CMID19 | CMID18 | CMID17 | CMID16 |

#### (b) CANn module mask 2 register (CnMASK2L, CnMASK2H)

Access These registers can be read/written in 16-bit units.

Address CnMASK2L: <CnRBaseAddr> + 044<sub>H</sub>

CnMASK2H: <CnRBaseAddr> + 046<sub>H</sub>

**Initial Value** Undefined.

CnMASK2L

| 15      | 14     | 13     | 12     | 11     | 10     | 9      | 8      |
|---------|--------|--------|--------|--------|--------|--------|--------|
| CMID15  | CMID14 | CMID13 | CMID12 | CMID11 | CMID10 | CMID9  | CMID8  |
| 7       | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| CMID7   | CMID6  | CMID5  | CMID4  | CMID3  | CMID2  | CMID1  | CMID0  |
|         |        |        |        |        |        |        |        |
| CnMASK2 | Н      |        |        |        |        |        |        |
| 15      | 14     | 13     | 12     | 11     | 10     | 9      | 8      |
| 0       | 0      | 0      | CMID28 | CMID27 | CMID26 | CMID25 | CMID24 |
| 7       | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| CMID23  | CMID22 | CMID21 | CMID20 | CMID19 | CMID18 | CMID17 | CMID16 |

# (c) CANn module mask 3 register (CnMASK3L, CnMASK3H)

Access These registers can be read/written in 16-bit units.

Address CnMASK3L: <CnRBaseAddr> + 048<sub>H</sub> CnMASK3H: <CnRBaseAddr> + 04A<sub>H</sub>

Initial Value Undefined.

| CnMASK3 | L      |        |        |        |        |       |       |
|---------|--------|--------|--------|--------|--------|-------|-------|
| 15      | 14     | 13     | 12     | 11     | 10     | 9     | 8     |
| CMID15  | CMID14 | CMID13 | CMID12 | CMID11 | CMID10 | CMID9 | CMID8 |
| 7       | 6      | 5      | 4      | 3      | 2      | 1     | 0     |
| CMID7   | CMID6  | CMID5  | CMID4  | CMID3  | CMID2  | CMID1 | CMID0 |
|         |        |        |        |        |        |       |       |
| CnMASK3 | Н      |        |        |        |        |       |       |
| 15      | 14     | 13     | 12     | 11     | 10     | 9     | 8     |

| 15     | 14     | 13     | 12     | 11     | 10     | 9      | 8      |
|--------|--------|--------|--------|--------|--------|--------|--------|
| 0      | 0      | 0      | CMID28 | CMID27 | CMID26 | CMID25 | CMID24 |
| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| CMID23 | CMID22 | CMID21 | CMID20 | CMID19 | CMID18 | CMID17 | CMID16 |

## (d) CANn module mask 4 register (CnMASK4L, CnMASK4H)

Access These registers can be read/written in 16-bit units.

Address (

S CnMASK4L: <CnRBaseAddr> + 04C<sub>H</sub> CnMASK4H: <CnRBaseAddr> + 04E<sub>H</sub>

Initial Value Undefined.

#### CnMASK4L

| 15     | 14     | 13     | 12     | 11     | 10     | 9     | 8     |
|--------|--------|--------|--------|--------|--------|-------|-------|
| CMID15 | CMID14 | CMID13 | CMID12 | CMID11 | CMID10 | CMID9 | CMID8 |
| 7      | 6      | 5      | 4      | 3      | 2      | 1     | 0     |
| CMID7  | CMID6  | CMID5  | CMID4  | CMID3  | CMID2  | CMID1 | CMID0 |
|        |        |        |        |        |        |       |       |

CnMASK4H

| 15     | 14     | 13     | 12     | 11     | 10     | 9      | 8      |
|--------|--------|--------|--------|--------|--------|--------|--------|
| 0      | 0      | 0      | CMID28 | CMID27 | CMID26 | CMID25 | CMID24 |
| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| CMID23 | CMID22 | CMID21 | CMID20 | CMID19 | CMID18 | CMID17 | CMID16 |

| CMID28 to CMID0 | Mask pattern setting of ID bit                                                                                                                       |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0               | The ID bits of the message buffer set by the CMID28 to CMID0 bits are compared with the ID bits of the received message frame.                       |
| 1               | The ID bits of the message buffer set by the CMID28 to CMID0 bits are not compared with the ID bits of the received message frame (they are masked). |

Note Masking is always defined by an ID length of 29 bits. If a mask is assigned to a message with a standard ID, the CMID17 to CMID0 bits are ignored. Therefore, only the CMID28 to CMID18 bits of the received ID are masked. The same mask can be used for both the standard and extended IDs.



# (6) CnCTRL - CANn module control register

The CnCTRL register is used to control the operation mode of the CAN module.

Access This register can be read/written in 16-bit units.

Address <CnRBaseAddr> + 050<sub>H</sub>

Initial Value 0000<sub>H</sub>. The register is initialized by any reset.

#### (a) CnCTRL read

| 15    | 14 | 13    | 12      | 11      | 10      | 9       | 8       |
|-------|----|-------|---------|---------|---------|---------|---------|
| 0     | 0  | 0     | 0       | 0       | 0       | RSTAT   | TSTAT   |
| 7     | 6  | 5     | 4       | 3       | 2       | 1       | 0       |
| CCERC | AL | VALID | PSMODE1 | PSMODE0 | OPMODE2 | OPMODE1 | OPMODE0 |

| RSTAT | Reception status bit      |
|-------|---------------------------|
| 0     | Reception is stopped.     |
| 1     | Reception is in progress. |

Note 1. The RSTAT bit is set to 1 under the following conditions (timing)

- The SOF bit of a receive frame is detected
- On occurrence of arbitration loss during a transmit frame
- 2. The RSTAT bit is cleared to 0 under the following conditions (timing)
  - When a recessive level is detected at the second bit of the interframe space
  - On transition to the initialization mode at the first bit of the interframe space

| TSTAT | Transmission status bit      |
|-------|------------------------------|
| 0     | Transmission is stopped.     |
| 1     | Transmission is in progress. |

- Note 1. The TSTAT bit is set to 1 under the following conditions (timing)
  - The SOF bit of a transmit frame is detected
  - 2. The TSTAT bit is cleared to 0 under the following conditions (timing)
    - · During transition to bus-off state
    - On occurrence of arbitration loss in transmit frame
    - On detection of recessive level at the second bit of the interframe space
    - On transition to the initialization mode at the first bit of the interframe space



| CCERC | Error counter clear bit                                                    |
|-------|----------------------------------------------------------------------------|
| 0     | The CnERC and CnINFO registers are not cleared in the initialization mode. |
| 1     | The CnERC and CnINFO registers are cleared in the initialization mode.     |

- Note 1. The CCERC bit is used to clear the CnERC and CnINFO registers for reinitialization or forced recovery from the bus-off state. This bit can be set to 1 only in the initialization mode.
  - 2. When the CnERC and CnINFO registers have been cleared, the CCERC bit is also cleared to 0 automatically.
  - 3. The CCERC bit can be set to 1 at the same time as a request to change the initialization mode to an operation mode is made.
  - 4. The CCERC bit is read-only in the CAN sleep mode or CAN stop mode.
  - 5. The receive data may be corrupted in case of setting the CCERC bit to (1) immediately after entering the INIT mode from self-test mode.

| AL | Bit to set operation in case of arbitration loss                                        |
|----|-----------------------------------------------------------------------------------------|
| 0  | Re-transmission is not executed in case of an arbitration loss in the single-shot mode. |
| 1  | Re-transmission is executed in case of an arbitration loss in the single-<br>shot mode. |

Note The AL bit is valid only in the single-shot mode.

| VALID | Valid receive message frame detection bit                                              |
|-------|----------------------------------------------------------------------------------------|
| 0     | A valid message frame has not been received since the VALID bit was last cleared to 0. |
| 1     | A valid message frame has been received since the VALID bit was last cleared to 0.     |

- Note 1. Detection of a valid receive message frame is not dependent upon storage in the receive message buffer (data frame) or transmit message buffer (remote frame).
  - 2. Clear the VALID bit (0) before changing the initialization mode to an operation mode.
  - 3. If only two CAN nodes are connected to the CAN bus with one transmitting a message frame in the normal mode and the other in the receive-only mode, the VALID bit is not set to 1 before the transmitting node enters the error passive state, because in receive-only mode no acknowledge is generated.
  - 4. To clear the VALID bit, set the Clear VALID bit to 1 first and confirm that the VALID bit is cleared. If it is not cleared, perform clearing processing again.



| PSMODE1 | PSMODE0 | Power save mode                 |  |
|---------|---------|---------------------------------|--|
| 0       | 0       | No power save mode is selected. |  |
| 0       | 1       | CAN sleep mode                  |  |
| 1       | 0       | Setting prohibited              |  |
| 1       | 1       | CAN stop mode                   |  |

**Caution** 1. Transition to and from the CAN stop mode must be made via CAN sleep mode. A request for direct transition to and from the CAN stop mode is ignored.

- 2. The MBON flag of CnGMCTRL must be checked after releasing a power save mode, prior to access the message buffers again.
- **3.** CAN sleep mode requests are kept pending, until cancelled by software or entered on appropriate bus condition (bus idle). Software can check the actual status by reading PSMODE.

| OPMODE2          | OPMODE1 | OPMODE0 | Operation mode                                                                                    |
|------------------|---------|---------|---------------------------------------------------------------------------------------------------|
| 0                | 0       | 0       | No operation mode is selected (CAN module is in the initialization mode).                         |
| 0                | 0       | 1       | Normal operation mode                                                                             |
| 0                | 1       | 0       | Normal operation mode with automatic block transmission function (normal operation mode with ABT) |
| 0                | 1       | 1       | Receive-only mode                                                                                 |
| 1                | 0       | 0       | Single-shot mode                                                                                  |
| 1                | 0       | 1       | Self-test mode                                                                                    |
| Other than above |         | ve      | Setting prohibited                                                                                |

**Caution** Transit to initialization mode or power saving modes may take some time. Be sure to verify the success of mode change by reading the values, before proceeding.

**Note** The OPMODE0 to OPMODE2 bits are read-only in the CAN sleep mode or CAN stop mode.

### (b) CnCTRL write

| 15           | 14        | 13 | 12             | 11             | 10             | 9              | 8              |
|--------------|-----------|----|----------------|----------------|----------------|----------------|----------------|
| Set<br>CCERC | Set<br>AL | 0  | Set<br>PSMODE1 | Set<br>PSMODE0 | Set<br>OPMODE2 | Set<br>OPMODE1 | Set<br>OPMODE0 |
|              |           |    |                |                |                |                |                |
| 7            | 6         | 5  | 4              | 3              | 2              | 1              | 0              |



| Set CCERC        | Setting of CCERC bit      |
|------------------|---------------------------|
| 1                | CCERC bit is set to 1.    |
| Other than above | CCERC bit is not changed. |

| Set AL           | Clear AL | Setting of AL bit       |
|------------------|----------|-------------------------|
| 0                | 1        | AL bit is cleared to 0. |
| 1                | 0        | AL bit is set to 1.     |
| Other than above |          | AL bit is not changed.  |

| Clear VALID | Setting of VALID bit       |
|-------------|----------------------------|
| 0           | VALID bit is not changed.  |
| 1           | VALID bit is cleared to 0. |

| Set<br>PSMODE0   | Clear<br>PSMODE0 | Setting of PSMODE0 bit       |
|------------------|------------------|------------------------------|
| 0                | 1                | PSMODE0 bit is cleared to 0. |
| 1                | 0                | PSMODE0 bit is set to 1.     |
| Other than above |                  | PSMODE0 bit is not changed.  |

| Set<br>PSMODE1 | Clear<br>PSMODE1 | Setting of PSMODE1 bit       |
|----------------|------------------|------------------------------|
| 0              | 1                | PSMODE1 bit is cleared to 0. |
| 1              | 0                | PSMODE1 bit is set to 1.     |
| Other that     | an above         | PSMODE1 bit is not changed.  |

| Set<br>OPMODE0   | Clear<br>OPMODE0 | Setting of OPMODE0 bit       |
|------------------|------------------|------------------------------|
| 0                | 1                | OPMODE0 bit is cleared to 0. |
| 1                | 0                | OPMODE0 bit is set to 1.     |
| Other than above |                  | OPMODE0 bit is not changed.  |

| Set<br>OPMODE1   | Clear<br>OPMODE1 | Setting of OPMODE1 bit       |  |
|------------------|------------------|------------------------------|--|
| 0                | 1                | OPMODE1 bit is cleared to 0. |  |
| 1                | 0                | OPMODE1 bit is set to 1.     |  |
| Other than above |                  | OPMODE1 bit is not changed.  |  |

| Set<br>OPMODE2 | Clear<br>OPMODE2 | Setting of OPMODE2 bit       |  |
|----------------|------------------|------------------------------|--|
| 0              | 1                | OPMODE2 bit is cleared to 0. |  |
| 1              | 0                | OPMODE2 bit is set to 1.     |  |
| Other the      | an above         | OPMODE2 bit is not changed.  |  |

(7) CnLEC - CANn module last error information registerThe CnLEC register provides the error information of the CAN protocol.

Access This register can be read/written in 8-bit units.



# Address <CnRBaseAddr> + 052<sub>H</sub>

Initial Value

 $\rm 00_{H}.$  The register is initialized by any reset.

| 7 | 6 | 5 | 4 | 3 | 2    | 1    | 0    |
|---|---|---|---|---|------|------|------|
| 0 | 0 | 0 | 0 | 0 | LEC2 | LEC1 | LEC0 |

- Note 1. The contents of the CnLEC register are not cleared when the CAN module changes from an operation mode to the initialization mode.
  - 2. If an attempt is made to write a value other than  $00_{H}$  to the CnLEC register by software, the access is ignored.

| LEC2 | LEC1 | LEC0 | Last CAN protocol error information                                                                                                                                                                         |
|------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | 0    | 0    | No error                                                                                                                                                                                                    |
| 0    | 0    | 1    | Stuff error                                                                                                                                                                                                 |
| 0    | 1    | 0    | Form error                                                                                                                                                                                                  |
| 0    | 1    | 1    | ACK error                                                                                                                                                                                                   |
| 1    | 0    | 0    | Bit error. (The CAN module tried to transmit a recessive-level<br>bit as part of a transmit message (except the arbitration field),<br>but the value on the CAN bus is a dominant-level bit.)               |
| 1    | 0    | 1    | Bit error. (The CAN module tried to transmit a dominant-level<br>bit as part of a transmit message, ACK bit, error frame, or<br>overload frame, but the value on the CAN bus is a recessive-<br>level bit.) |
| 1    | 1    | 0    | CRC error                                                                                                                                                                                                   |
| 1    | 1    | 1    | Undefined                                                                                                                                                                                                   |



# (8) CnINFO - CANn module information register

The CnINFO register indicates the status of the CAN module.

Access This register is read-only in 8-bit units.

Address <CnRBaseAddr> + 053<sub>H</sub>

Initial Value  $00_{\text{H}}$ . The register is initialized by any reset.

| 7 | 6 | 5 | 4    | 3     | 2     | 1     | 0     |
|---|---|---|------|-------|-------|-------|-------|
| 0 | 0 | 0 | BOFF | TECS1 | TECS0 | RECS1 | RECS0 |

| BOFF | Bus-off state bit                                                                                            |
|------|--------------------------------------------------------------------------------------------------------------|
| 0    | Not bus-off state (transmit error counter $\leq$ 255). (The value of the transmit counter is less than 256.) |
| 1    | Bus-off state (transmit error counter > 255). (The value of the transmit counter is 256 or more.)            |

| TECS1 | TECS0 | Transmission error counter status bit                                                                             |
|-------|-------|-------------------------------------------------------------------------------------------------------------------|
| 0     | 0     | The value of the transmission error counter is less than that of the warning level (< 96).                        |
| 0     | 1     | The value of the transmission error counter is in the range of the warning level (96 to 127).                     |
| 1     | 0     | Undefined                                                                                                         |
| 1     | 1     | The value of the transmission error counter is in the range of the error passive or bus-off status ( $\geq$ 128). |

| RECS1 | RECS0 | Reception error counter status bit                                                         |
|-------|-------|--------------------------------------------------------------------------------------------|
| 0     | 0     | The value of the reception error counter is less than that of the warning level (< 96).    |
| 0     | 1     | The value of the reception error counter is in the range of the warning level (96 to 127). |
| 1     | 0     | Undefined                                                                                  |
| 1     | 1     | The value of the reception error counter is in the error passive range ( $\geq$ 128).      |



# (9) CnERC - CANn module error counter register

The CnERC register indicates the count value of the transmission/reception error counter.

Access This register is read-only in 16-bit units.

Address <CnRBaseAddr> + 054<sub>H</sub>

Initial Value 0000<sub>H</sub>. The register is initialized by any reset.

| 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    |
|------|------|------|------|------|------|------|------|
| REPS | REC6 | REC5 | REC4 | REC3 | REC2 | REC1 | REC0 |
| 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| TEC7 | TEC6 | TEC5 | TEC4 | TEC3 | TEC2 | TEC1 | TEC0 |

| REPS | Reception error passive status bit                                      |  |  |
|------|-------------------------------------------------------------------------|--|--|
| 0    | The reception error counter is not in the error passive range (< 128)   |  |  |
| 1    | The reception error counter is in the error passive range ( $\geq$ 128) |  |  |

| REC6 to REC0 | Reception error counter bit                                                                                                                    |  |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0 to 127     | Number of reception errors. These bits reflect the status of the reception error counter. The number of errors is defined by the CAN protocol. |  |

**Note** REC6 to REC0 of the reception error counter are invalid in the reception error passive state (CnINFO.RECS[1:0] =  $11_B$ ).

| TEC7 to TEC0 Transmission error counter bit |                                                                                                                                                      |
|---------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 to 255                                    | Number of transmission errors. These bits reflect the status of the transmission error counter. The number of errors is defined by the CAN protocol. |

**Note** The TEC7 to TEC0 bits of the transmission error counter are invalid in the busoff state (CnINFO.BOFF = 1).



## (10) CnIE - CANn module interrupt enable register

The CnIE register is used to enable or disable the interrupts of the CAN module.

Access This register can be read/written in 16-bit units.

Address <CnRBaseAddr> + 056<sub>H</sub>

Initial Value 0000<sub>H</sub>. The register is initialized by any reset.

# (a) CnIE read

| 15 | 14 | 13   | 12   | 11   | 10   | 9    | 8    |
|----|----|------|------|------|------|------|------|
| 0  | 0  | 0    | 0    | 0    | 0    | 0    | 0    |
| 7  | 6  | 5    | 4    | 3    | 2    | 1    | 0    |
| 0  | 0  | CIE5 | CIE4 | CIE3 | CIE2 | CIE1 | CIE0 |

| CIE5 to CIE0 | CAN module interrupt enable bit                                                        |
|--------------|----------------------------------------------------------------------------------------|
| 0            | Output of the interrupt corresponding to interrupt status register CINTSx is disabled. |
| 1            | Output of the interrupt corresponding to interrupt status register CINTSx is enabled.  |

# (b) CnIE write

| 15 | 14 | 13            | 12            | 11            | 10            | 9             | 8             |
|----|----|---------------|---------------|---------------|---------------|---------------|---------------|
| 0  | 0  | Set<br>CIE5   | Set<br>CIE4   | Set<br>CIE3   | Set<br>CIE2   | Set<br>CIE1   | Set<br>CIE0   |
| 7  | 6  | 5             | 4             | 3             | 2             | 1             | 0             |
| 0  | 0  | Clear<br>CIE5 | Clear<br>CIE4 | Clear<br>CIE3 | Clear<br>CIE2 | Clear<br>CIE1 | Clear<br>CIE0 |

| Set CIE5   | Clear CIE5 | Setting of CIE5 bit       |
|------------|------------|---------------------------|
| 0          | 1          | CIE5 bit is cleared to 0. |
| 1          | 0          | CIE5 bit is set to 1.     |
| Other that | an above   | CIE5 bit is not changed.  |

| Set CIE4         | Clear CIE4 | Setting of CIE4 bit       |
|------------------|------------|---------------------------|
| 0                | 1          | CIE4 bit is cleared to 0. |
| 1                | 0          | CIE4 bit is set to 1.     |
| Other than above |            | CIE4 bit is not changed.  |

| Set CIE3         | Clear CIE3 | Setting of CIE3 bit       |
|------------------|------------|---------------------------|
| 0                | 1          | CIE3 bit is cleared to 0. |
| 1                | 0          | CIE3 bit is set to 1.     |
| Other than above |            | CIE3 bit is not changed.  |



| Set CIE2         | Clear CIE2 | Setting of CIE2 bit       |
|------------------|------------|---------------------------|
| 0                | 1          | CIE2 bit is cleared to 0. |
| 1                | 0          | CIE2 bit is set to 1.     |
| Other than above |            | CIE2 bit is not changed.  |

| Set CIE1         | Clear CIE1 | Setting of CIE1 bit       |
|------------------|------------|---------------------------|
| 0                | 1          | CIE1 bit is cleared to 0. |
| 1                | 0          | CIE1 bit is set to 1.     |
| Other than above |            | CIE1 bit is not changed.  |

| Set CIE0         | Clear CIE0 | Setting of CIE0 bit       |
|------------------|------------|---------------------------|
| 0                | 1          | CIE0 bit is cleared to 0. |
| 1                | 0          | CIE0 bit is set to 1.     |
| Other than above |            | CIE0 bit is not changed.  |



# (11) CnINTS - CANn module interrupt status register

The CnINTS register indicates the interrupt status of the CAN module.

Access This register can be read/written in 16-bit units.

Address <CnRBaseAddr> + 058<sub>H</sub>

Initial Value 0000<sub>H</sub>. The register is initialized by any reset.

# (a) CnINTS read

| 15 | 14 | 13     | 12     | 11     | 10     | 9      | 8      |
|----|----|--------|--------|--------|--------|--------|--------|
| 0  | 0  | 0      | 0      | 0      | 0      | 0      | 0      |
| 7  | 6  | 5      | 4      | 3      | 2      | 1      | 0      |
| 0  | 0  | CINTS5 | CINTS4 | CINTS3 | CINTS2 | CINTS1 | CINTS0 |

| CINTS5 to CINTS0 | CAN interrupt status bit                      |
|------------------|-----------------------------------------------|
| 0                | No related interrupt source event is pending. |
| 1                | A related interrupt source event is pending.  |

| Interrupt status bit | Related interrupt source event                                                        |
|----------------------|---------------------------------------------------------------------------------------|
| CINTS5               | Wakeup interrupt from CAN sleep mode <sup>a</sup>                                     |
| CINTS4               | Arbitration loss interrupt                                                            |
| CINTS3               | CAN protocol error interrupt                                                          |
| CINTS2               | CAN error status interrupt                                                            |
| CINTS1               | Interrupt on completion of reception of valid message frame to message buffer m       |
| CINTS0               | Interrupt on normal completion of transmission of message frame from message buffer m |

a) The CINTS5 bit is set only when the CAN module is woken up from the CAN sleep mode by a CAN bus operation. The CINTS5 bit is not set when the CAN sleep mode has been released by software.

### (b) CnINTS write

| 15 | 14 | 13              | 12              | 11              | 10              | 9               | 8               |
|----|----|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|
| 0  | 0  | 0               | 0               | 0               | 0               | 0               | 0               |
| 7  | 6  | 5               | 4               | 3               | 2               | 1               | 0               |
| 0  | 0  | Clear<br>CINTS5 | Clear<br>CINTS4 | Clear<br>CINTS3 | Clear<br>CINTS2 | Clear<br>CINTS1 | Clear<br>CINTS0 |

| Clear<br>CINTS5 to CINTS0 Setting of CINTS5 to CINTS0 bits |                                         |
|------------------------------------------------------------|-----------------------------------------|
| 0                                                          | CINTS5 to CINTS0 bits are not changed.  |
| 1                                                          | CINTS5 to CINTS0 bits are cleared to 0. |

#### Caution

Please clear the status bit of this register with software when the confirmation of each status is necessary in the interrupt processing, because these bits are not cleared automatically.



### (12) CnBRP - CANn module bit rate prescaler register

The CnBRP register is used to select the CAN protocol layer basic system clock ( $f_{TO}$ ). The communication baud rate is set to the CnBTR register.

Access This register can be read/written in 8-bit units.

Address <CnRBaseAddr> + 05A<sub>H</sub>

Initial Value FF<sub>H</sub>. The register is initialized by any reset.

| 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |  |
|--------|--------|--------|--------|--------|--------|--------|--------|--|
| TQPRS7 | TQPRS6 | TQPRS5 | TQPRS4 | TQPRS3 | TQPRS2 | TQPRS1 | TQPRS0 |  |

| TQPRS7 to TQPRS0 | CAN protocol layer base system clock (f <sub>TQ</sub> ) |
|------------------|---------------------------------------------------------|
| 0                | f <sub>CANMOD</sub> /1                                  |
| 1                | f <sub>CANMOD</sub> /2                                  |
| n                | f <sub>CANMOD</sub> /(n+1)                              |
| :                | :                                                       |
| 255              | f <sub>CANMOD</sub> /256 (default value)                |



Figure 14-24 CAN module clock

 Note
 f<sub>CAN</sub>:
 clock supplied to CAN

 f<sub>CANMOD</sub>:
 CAN module system clock

 f<sub>TQ</sub>:
 CAN protocol layer basic system clock

Caution

The CnBRP register can be write-accessed only in the initialization mode.



# (13) CnBTR - CANn module bit rate register

The CnBTR register is used to control the data bit time of the communication baud rate.

- Access This register can be read/written in 16-bit units.
- Address <CnRBaseAddr> + 05C<sub>H</sub>

Initial Value 370F<sub>H</sub>. The register is initialized by any reset.

| 15 | 14 | 13   | 12   | 11     | 10     | 9      | 8      |
|----|----|------|------|--------|--------|--------|--------|
| 0  | 0  | SJW1 | SJW0 | 0      | TSEG22 | TSEG21 | TSEG20 |
| 7  | 6  | 5    | 4    | 3      | 2      | 1      | 0      |
| 0  | 0  | 0    | 0    | TSEG13 | TSEG12 | TSEG11 | TSEG10 |



#### Figure 14-25 Data bit time

| SJW1 | SJW0 | ength of synchronization jump width |  |  |  |
|------|------|-------------------------------------|--|--|--|
| 0    | 0    | 1T <sub>Q</sub>                     |  |  |  |
| 0    | 1    | 2T <sub>Q</sub>                     |  |  |  |
| 1    | 0    | ЗТ <sub>Q</sub>                     |  |  |  |
| 1    | 1    | 4T <sub>Q</sub> (default value)     |  |  |  |

| TSEG22 | TSEG21 | TSEG20 | Length of time segment 2        |
|--------|--------|--------|---------------------------------|
| 0      | 0      | 0      | 1T <sub>Q</sub>                 |
| 0      | 0      | 1      | 2T <sub>Q</sub>                 |
| 0      | 1      | 0      | 3T <sub>Q</sub>                 |
| 0      | 1      | 1      | 4T <sub>Q</sub>                 |
| 1      | 0      | 0      | 5T <sub>Q</sub>                 |
| 1      | 0      | 1      | 6T <sub>Q</sub>                 |
| 1      | 1      | 0      | 7T <sub>Q</sub>                 |
| 1      | 1      | 1      | 8T <sub>Q</sub> (default value) |



| TSEG13 | TSEG12 | TSEG11 | TSEG10 | Length of time segment 1         |  |  |
|--------|--------|--------|--------|----------------------------------|--|--|
| 0      | 0      | 0      | 0      | Setting prohibited               |  |  |
| 0      | 0      | 0      | 1      | 2T <sub>Q</sub> <sup>a</sup>     |  |  |
| 0      | 0      | 1      | 0      | 3T <sub>Q</sub> <sup>a</sup>     |  |  |
| 0      | 0      | 1      | 1      | 4T <sub>Q</sub>                  |  |  |
| 0      | 1      | 0      | 0      | 5T <sub>Q</sub>                  |  |  |
| 0      | 1      | 0      | 1      | 6T <sub>Q</sub>                  |  |  |
| 0      | 1      | 1      | 0      | 7T <sub>Q</sub>                  |  |  |
| 0      | 1      | 1      | 1      | 8T <sub>Q</sub>                  |  |  |
| 1      | 0      | 0      | 0      | 9T <sub>Q</sub>                  |  |  |
| 1      | 0      | 0      | 1      | 10T <sub>Q</sub>                 |  |  |
| 1      | 0      | 1      | 0      | 11T <sub>Q</sub>                 |  |  |
| 1      | 0      | 1      | 1      | 12T <sub>Q</sub>                 |  |  |
| 1      | 1      | 0      | 0      | 13T <sub>Q</sub>                 |  |  |
| 1      | 1      | 0      | 1      | 14T <sub>Q</sub>                 |  |  |
| 1      | 1      | 1      | 0      | 15T <sub>Q</sub>                 |  |  |
| 1      | 1      | 1      | 1      | 16T <sub>Q</sub> (default value) |  |  |

This setting must not be made when the CnBRP register =  $00_{H}$ 

**Note**  $T_Q = 1/f_{TQ}$  ( $f_{TQ}$ : CAN protocol layer basic system clock)

# (14) CnLIPT - CANn module last in-pointer register

The CnLIPT register indicates the number of the message buffer in which a data frame or a remote frame was last stored.

Access This register is read-only in 8-bit units.

Address <CnRBaseAddr> + 05E<sub>H</sub>

Initial Value Undefined.

a)

| 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|-------|-------|-------|-------|-------|-------|-------|
| LIPT7 | LIPT6 | LIPT5 | LIPT4 | LIPT3 | LIPT2 | LIPT1 | LIPT0 |

| LIPT7 to LIPT0 | Last in-pointer register (CnLIPT)                                                                                                                                                                                                                                    |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 to 31        | When the CnLIPT register is read, the contents of the element<br>indexed by the last in-pointer (LIPT) of the receive history list are<br>read. These contents indicate the number of the message buffer in<br>which a data frame or a remote frame was last stored. |

**Note** The read value of the CnLIPT register is undefined if a data frame or a remote frame has never been stored in the message buffer. If the RHPM bit of the CnRGPT register is set to 1 after the CAN module has changed from the initialization mode to an operation mode, therefore, the read value of the CnLIPT register is undefined.

RENESAS

# (15) CnRGPT - CANn module receive history list register

The CnRGPT register is used to read the receive history list.

Access This register can be read/written in 16-bit units.

Address <CnRBaseAddr> + 060<sub>H</sub>

Initial Value xx02<sub>H</sub>. The register is initialized by any reset.

# (a) CnRGPT read

| 15    | 14    | 13    | 12    | 11    | 10    | 9     | 8     |
|-------|-------|-------|-------|-------|-------|-------|-------|
| RGPT7 | RGPT6 | RGPT5 | RGPT4 | RGPT3 | RGPT2 | RGPT1 | RGPT0 |
| 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| 0     | 0     | 0     | 0     | 0     | 0     | RHPM  | ROVF  |

| RGPT7<br>to<br>RGPT0 | Receive history list read pointer                                                                                                                                                                                                                                                     |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 to 31              | When the CnRGPT register is read, the contents of the element indexed<br>by the receive history list get pointer (RGPT) of the receive history list are<br>read. These contents indicate the number of the message buffer in which<br>a data frame or a remote frame has been stored. |

| RHPM <sup>a</sup> | Receive history list pointer match                                                      |  |  |  |  |
|-------------------|-----------------------------------------------------------------------------------------|--|--|--|--|
| 0                 | The receive history list has at least one message buffer number that has not been read. |  |  |  |  |
| 1                 | The receive history list has no message buffer numbers that have not been read.         |  |  |  |  |

a) The read value of the RGPT0 to RGPT7 bits is invalid when the RHPM bit = 1.

| ROVF <sup>a</sup> | Receive history list overflow bit                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                 | All the message buffer numbers that have not been read are preserved.<br>All the numbers of the message buffers in which a new data frame or<br>remote frame has been received and stored are recorded to the receive<br>history list (the receive history list has a vacant element).                                                                                                                                             |
| 1                 | At least 23 entries have been stored since the host processor has<br>serviced the RHL last<br>time (i.e. read CnRGPT). The first 22 entries are sequentially stored while<br>the last entry<br>can have been overwritten whenever newly received message is stored<br>because all buffer<br>numbers are stored at position LIPT-1 when ROVF bit is set. Thus the<br>sequence of<br>receptions can not be recovered completely now. |

<sup>a)</sup> If ROVF is set, RHPM is no longer cleared on message storage, but RHPM is still set, if all entries of CnRGPT are read by software.



# (b) CnRGPT write

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8             |
|----|----|----|----|----|----|---|---------------|
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0             |
| 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0             |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | Clear<br>ROVF |

| Clear ROVF | Setting of ROVF bit       |  |  |  |
|------------|---------------------------|--|--|--|
| 0          | ROVF bit is not changed.  |  |  |  |
| 1          | ROVF bit is cleared to 0. |  |  |  |

# (16) CnLOPT - CANn module last out-pointer register

The CnLOPT register indicates the number of the message buffer to which a data frame or a remote frame was transmitted last.

Access This register is read-only in 8-bit units.

Address <CnRBaseAddr> + 062<sub>H</sub>

# Initial Value Undefined

| 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|-------|-------|-------|-------|-------|-------|-------|
| LOPT7 | LOPT6 | LOPT5 | LOPT4 | LOPT3 | LOPT2 | LOPT1 | LOPT0 |

| LOPT7 to<br>LOPT0 | Last out-pointer of transmit history list (LOPT)                                                                                                                                                                                                                           |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 to 31           | When the CnLOPT register is read, the contents of the element indexed<br>by the last out-pointer (LOPT) of the receive history list are read. These<br>contents indicate the number of the message buffer to which a data frame<br>or a remote frame was transmitted last. |

Note The value read from the CnLOPT register is undefined if a data frame or remote frame has never been transmitted from a message buffer. If the CnTGPT.THPM bit is set to 1 after the CAN module has changed from the initialization mode to an operation mode, therefore, the read value of the CnLOPT register is undefined.



# (17) CnTGPT - CANn module transmit history list register

The CnTGPT register is used to read the transmit history list.

Access This register can be read/written in 16-bit units.

Address <CnRBaseAddr> + 064<sub>H</sub>

Initial Value xx02<sub>H</sub>. The register is initialized by any reset.

# (a) CnTGPT read

| 15    | 14    | 13    | 12    | 11    | 10    | 9     | 8     |
|-------|-------|-------|-------|-------|-------|-------|-------|
| TGPT7 | TGPT6 | TGPT5 | TGPT4 | TGPT3 | TGPT2 | TGPT1 | TGPT0 |
| 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| 0     | 0     | 0     | 0     | 0     | 0     | THPM  | TOVF  |

| TGPT7 to<br>TGPT0 | Transmit history list read pointer                                                                                                                                                                                                                                      |  |  |  |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0 to 31           | When the CnTGPT register is read, the contents of the element indexed<br>by the read pointer (TGPT) of the transmit history list are read. These<br>contents indicate the number of the message buffer to which a data frame<br>or a remote frame was transmitted last. |  |  |  |

| THPM <sup>a</sup> | Transmit history pointer match                                                           |
|-------------------|------------------------------------------------------------------------------------------|
| 0                 | The transmit history list has at least one message buffer number that has not been read. |
| 1                 | The transmit history list has no message buffer numbers that have not been read.         |

a) The read value of the TGPT0 to TGPT7 bits is invalid when the THPM bit = 1.

| TOVF <sup>a</sup> | Transmit history list overflow bit                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                 | All the message buffer numbers that have not been read are preserved.<br>All the numbers of the message buffers to which a new data frame or<br>remote frame has been transmitted are recorded to the transmit history<br>list (the transmit history list has a vacant element).                                                                                                                                                  |
| 1                 | At least 7 entries have been stored since the host processor has serviced<br>the THL last<br>time (i.e. read CnTGPT). The first 6 entries are sequentially stored while<br>the last entry<br>can have been overwritten whenever a message is newly transmitted<br>because all buffer<br>numbers are stored at position LOPT-1 when TOVF bit is set. Thus the<br>sequence of<br>transmissions can not be recovered completely now. |

a) If TOVF is set, THPM is no longer cleared on message transmission, but THPM is still set, if all entries of CnTGPT are read by software.

**Note** Transmission from message buffers 0 to 7 is not recorded to the transmit history list in the normal operation mode with ABT.



# (b) CnTGPT write

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8             |
|----|----|----|----|----|----|---|---------------|
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0             |
| 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0             |
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | Clear<br>TOVF |

| Clear<br>TOVF | Setting of TOVF bit       |
|---------------|---------------------------|
| 0             | TOVF bit is not changed.  |
| 1             | TOVF bit is cleared to 0. |



# (18) CnTS - CANn module time stamp register

The CnTS register is used to control the time stamp function.

Access This register can be read/written in 16-bit units.

Address <CnRBaseAddr> + 066<sub>H</sub>

Initial Value 0000<sub>H</sub>. The register is initialized by any reset.

# (a) CnTS read

| 15 | 14 | 13 | 12 | 11 | 10     | 9     | 8    |
|----|----|----|----|----|--------|-------|------|
| 0  | 0  | 0  | 0  | 0  | 0      | 0     | 0    |
| 7  | 6  | 5  | 4  | 3  | 2      | 1     | 0    |
| 0  | 0  | 0  | 0  | 0  | TSLOCK | TSSEL | TSEN |

**Note** The lock function of the time stamp function must not be used when the CAN module is in the normal operation mode with ABT.

| TSLOCK | Time stamp lock function enable bit                                                                                                                                                                                                                           |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | Time stamp lock function stopped.<br>The TSOUT signal is toggled each time the selected time stamp capture<br>event occurs.                                                                                                                                   |
| 1      | Time stamp lock function enabled.<br>The TSOUT signal is toggled each time the selected time stamp capture<br>event occurs.<br>However, the TSOUT output signal is locked when a data frame has been<br>correctly received to message buffer 0 <sup>a</sup> . |

a) The TSEN bit is automatically cleared to 0.

| TSSEL | Time stamp capture event selection bit               |
|-------|------------------------------------------------------|
| 0     | The time capture event is SOF.                       |
| 1     | The time stamp capture event is the last bit of EOF. |

| TSEN | TSOUT operation setting bit         |
|------|-------------------------------------|
| 0    | TSOUT toggle operation is disabled. |
| 1    | TSOUT toggle operation is enabled.  |



# (b) CnTS write

| 15 | 14 | 13 | 12 | 11 | 10              | 9              | 8             |
|----|----|----|----|----|-----------------|----------------|---------------|
| 0  | 0  | 0  | 0  | 0  | Set<br>TSLOCK   | Set<br>TSSEL   | Set<br>TSEN   |
| 7  | 6  | 5  | 4  | 3  | 2               | 1              | 0             |
| 0  | 0  | 0  | 0  | 0  | Clear<br>TSLOCK | Clear<br>TSSEL | Clear<br>TSEN |

| Set<br>TSLOCK    | Clear<br>TSLOCK | Setting of TSLOCK bit       |
|------------------|-----------------|-----------------------------|
| 0                | 1               | TSLOCK bit is cleared to 0. |
| 1                | 0               | TSLOCK bit is set to 1.     |
| Other than above |                 | TSLOCK bit is not changed.  |

| Set<br>TSSEL     | Clear<br>TSSEL | Setting of TSSEL bit       |
|------------------|----------------|----------------------------|
| 0                | 1              | TSSEL bit is cleared to 0. |
| 1                | 0              | TSSEL bit is set to 1.     |
| Other than above |                | TSSEL bit is not changed.  |

| Set<br>TSEN      | Clear<br>TSEN | Setting of TSEN bit       |
|------------------|---------------|---------------------------|
| 0                | 1             | TSEN bit is cleared to 0. |
| 1 0              |               | TSEN bit is set to 1.     |
| Other than above |               | TSEN bit is not changed.  |



| Access The CnMDATAzm registers can be read/written in 16-bit units.<br>The CnMDATAxm registers can be read/written in 8-bit units. |             |            |           |           |           |          |          |
|------------------------------------------------------------------------------------------------------------------------------------|-------------|------------|-----------|-----------|-----------|----------|----------|
| Address Refer to "CAN registers overview" on page 395.                                                                             |             |            |           |           |           |          |          |
| Init                                                                                                                               | ial Value U | Indefined. |           |           |           |          |          |
|                                                                                                                                    |             |            |           |           |           |          |          |
| CnMDATA01n                                                                                                                         |             |            |           |           |           |          |          |
| 15                                                                                                                                 | 14          | 13         | 12        | 11        | 10        | 9        | 8        |
| MDATA0115                                                                                                                          | MDATA0114   | MDATA0113  | MDATA0112 | MDATA0111 | MDATA0110 | MDATA019 | MDATA018 |
| 7                                                                                                                                  | 6           | 5          | 4         | 3         | 2         | 1        | 0        |
| MDATA017                                                                                                                           | MDATA016    | MDATA015   | MDATA014  | MDATA013  | MDATA012  | MDATA011 | MDATA010 |
| CnMDATA0m<br>7                                                                                                                     | 6           | 5          | 4         | 3         | 2         | 1        | 0        |
| MDATA07                                                                                                                            | MDATA06     | MDATA05    | MDATA04   | MDATA03   | MDATA02   | MDATA01  | MDATA00  |
| CnMDATA1m<br>7                                                                                                                     | 6           | 5          | 4         | 3         | 2         | 1        | 0        |
| MDATA17                                                                                                                            | MDATA16     | MDATA15    | MDATA14   | MDATA13   | MDATA12   | MDATA11  | MDATA1   |
| CnMDATA23r                                                                                                                         | n           |            |           |           |           |          |          |
| 15                                                                                                                                 | 14          | 13         | 12        | 11        | 10        | 9        | 8        |
| MDATA2315                                                                                                                          | MDATA2314   | MDATA2313  | MDATA2312 | MDATA2311 | MDATA2310 | MDATA239 | MDATA238 |
| 7                                                                                                                                  | 6           | 5          | 4         | 3         | 2         | 1        | 0        |
| MDATA237                                                                                                                           | MDATA236    | MDATA235   | MDATA234  | MDATA233  | MDATA232  | MDATA231 | MDATA230 |
| CnMDATA2m                                                                                                                          |             |            |           |           |           |          |          |
| 7                                                                                                                                  | 6           | 5          | 4         | 3         | 2         | 1        | 0        |
| MDATA27                                                                                                                            | MDATA26     | MDATA25    | MDATA24   | MDATA23   | MDATA22   | MDATA21  | MDATA20  |
| CnMDATA3m                                                                                                                          |             |            |           |           |           |          |          |
| 7                                                                                                                                  | 6           | 5          | 4         | 3         | 2         | 1        | 0        |
|                                                                                                                                    |             |            |           |           |           |          |          |

CnMDATAxm, CnMDATAzm - CANn message data byte register (x = 0 to 7,

The CnMDATAxm, CnMDATAzm registers are used to store the data of a

(19)

z = 01, 23, 45, 67)

transmit/receive message.



| 0 1 1D 1T |      |
|-----------|------|
| CnMDATA   | \45m |

| 011112/11/101 |           |           |           |           |           |          |          |
|---------------|-----------|-----------|-----------|-----------|-----------|----------|----------|
| 15            | 14        | 13        | 12        | 11        | 10        | 9        | 8        |
| MDATA4515     | MDATA4514 | MDATA4513 | MDATA4512 | MDATA4511 | MDATA4510 | MDATA459 | MDATA458 |
| 7             | 6         | 5         | 4         | 3         | 2         | 1        | 0        |
| MDATA457      | MDATA456  | MDATA455  | MDATA454  | MDATA453  | MDATA452  | MDATA451 | MDATA450 |
|               |           |           |           |           |           |          |          |
| CnMDATA4m     |           |           |           |           |           |          |          |
| 7             | 6         | 5         | 4         | 3         | 2         | 1        | 0        |
| MDATA47       | MDATA46   | MDATA45   | MDATA44   | MDATA43   | MDATA42   | MDATA41  | MDATA40  |
|               |           |           |           |           |           |          |          |
| CnMDATA5m     |           |           |           |           |           |          |          |
| 7             | 6         | 5         | 4         | 3         | 2         | 1        | 0        |
| MDATA57       | MDATA56   | MDATA55   | MDATA54   | MDATA53   | MDATA52   | MDATA51  | MDATA50  |
|               |           |           |           |           |           |          |          |
| CnMDATA67r    | n         |           |           |           |           |          |          |
| 15            | 14        | 13        | 12        | 11        | 10        | 9        | 8        |
| MDATA6715     | MDATA6714 | MDATA6713 | MDATA6712 | MDATA6711 | MDATA6710 | MDATA679 | MDATA678 |
| 7             | 6         | 5         | 4         | 3         | 2         | 1        | 0        |
| MDATA677      | MDATA676  | MDATA675  | MDATA674  | MDATA673  | MDATA672  | MDATA671 | MDATA670 |
|               |           |           |           |           |           |          |          |
| CnMDATA6m     |           |           |           |           |           |          |          |
| 7             | 6         | 5         | 4         | 3         | 2         | 1        | 0        |
| MDATA67       | MDATA66   | MDATA65   | MDATA64   | MDATA63   | MDATA62   | MDATA61  | MDATA60  |
|               |           |           |           |           |           |          |          |
| CnMDATA7m     |           |           |           |           |           |          |          |
| 7             | 6         | 5         | 4         | 3         | 2         | 1        | 0        |
| MDATA77       | MDATA76   | MDATA75   | MDATA74   | MDATA73   | MDATA72   | MDATA71  | MDATA70  |
|               | •         |           | •         |           |           |          |          |



#### CnMDLCm - CANn message data length register m (20)

The CnMDLCm register is used to set the number of bytes of the data field of a message buffer.

Access This register can be read/written in 8-bit units.

Address Refer to "CAN registers overview" on page 395.

**Initial Value** 0000xxxx<sub>B</sub>. The register is initialized by any reset.

| 7 | 6 | 5 | 4 | 3     | 2     | 1     | 0     |  |
|---|---|---|---|-------|-------|-------|-------|--|
| 0 | 0 | 0 | 0 | MDLC3 | MDLC2 | MDLC1 | MDLC0 |  |

| MDLC3 | MDLC2 | MDLC1 | MDLC0                                                                                     | Data length of transmit/receive message                                                          |
|-------|-------|-------|-------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|
| 0     | 0     | 0     | 0                                                                                         | 0 bytes                                                                                          |
| 0     | 0     | 0     | 1                                                                                         | 1 byte                                                                                           |
| 0     | 0     | 1     | 0                                                                                         | 2 bytes                                                                                          |
| 0     | 0     | 1     | 1                                                                                         | 3 bytes                                                                                          |
| 0     | 1     | 0     | 0                                                                                         | 4 bytes                                                                                          |
| 0     | 1     | 0     | 1                                                                                         | 5 bytes                                                                                          |
| 0     | 1     | 1     | 0                                                                                         | 6 bytes                                                                                          |
| 0     | 1     | 1     | 1                                                                                         | 7 bytes                                                                                          |
| 1     | 0     | 0     | 0                                                                                         | 8 bytes                                                                                          |
| 1     | 0     | 0     | 1                                                                                         | Setting prohibited                                                                               |
| 1     | 0     | 1     | 0                                                                                         | (If these bits are set during transmission, 8-<br>byte data is transmitted regardless of the set |
| 1     | 0     | 1     | 1         DLC value when a data frame           0         However, the DLC actually trans | DLC value when a data frame is transmitted.                                                      |
| 1     | 1     | 0     |                                                                                           | However, the DLC actually transmitted to the<br>CAN bus is the DLC value set to this             |
| 1     | 1     | 0     | 1                                                                                         | register.) <sup>Note</sup>                                                                       |
| 1     | 1     | 1     | 0                                                                                         |                                                                                                  |
| 1     | 1     | 1     | 1                                                                                         |                                                                                                  |

Note The data and DLC value actually transmitted to CAN bus are as follows.

| Type of transmit<br>frame | Length of transmit data                                             | DLC transmitted        |  |
|---------------------------|---------------------------------------------------------------------|------------------------|--|
| Data frame                | Number of bytes specified by DLC (However, 8 bytes if $DLC \ge 8$ ) | MDLC3 to MDLC0<br>bits |  |
| Remote frame              | 0 bytes                                                             |                        |  |

**Caution** 1. Be sure to set bits 7 to 4 to  $0000_{\text{B}}$ .

2. Receive data is stored in as many CnMDATAxm register as the number of bytes (however, the upper limit is 8) corresponding to DLC of the received frame. The CnMDATAxm register in which no data is stored is undefined.



# (21) CnMCONFm - CANn message configuration register m

The CnMCONFm register is used to specify the type of the message buffer and to set a mask.

Access This register can be read/written in 8-bit units.

Address Refer to "CAN registers overview" on page 395.

Initial Value Undefined.

| 7   | 6   | 5   | 4   | 3   | 2 | 1 | 0   |
|-----|-----|-----|-----|-----|---|---|-----|
| OWS | RTR | MT2 | MT1 | MT0 | 0 | 0 | MA0 |

| OWS | Overwrite control bit                                                                                                                                                 |  |  |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0   | The message buffer that has already received a data frame <sup>a</sup> is not overwritten by a newly received data frame. The newly received data frame is discarded. |  |  |
| 1   | The message buffer that has already received a data frame <sup>a</sup> is overwritten by a newly received data frame.                                                 |  |  |

<sup>a)</sup> The "message buffer that has already received a data frame" is a receive message buffer whose the CnMCTRLm.DN bit has been set to 1.

Note A remote frame is received and stored, regardless of the setting of OWS and DN. A remote frame that satisfies the other conditions (ID matches, RTR = 0, TRQ = 0) is always received and stored in the corresponding message buffer (interrupt generated, DN flag set, MDLC[3:0] updated, and recorded to the receive history list).

|                            | RTR | Remote frame request bit <sup>a</sup> |  |  |
|----------------------------|-----|---------------------------------------|--|--|
| Ī                          | 0   | Transmit a data frame.                |  |  |
| 1 Transmit a remote frame. |     | Transmit a remote frame.              |  |  |

a) The RTR bit specifies the type of message frame that is transmitted from a message buffer defined as a transmit message buffer. Even if a valid remote frame has been received, the RTR bit of the transmit message buffer that has received the frame remains cleared to 0. Even if a remote frame whose ID matches has been received from the CAN bus with the RTR bit of the transmit message buffer set to 1 to transmit a remote frame, that remote frame is not received or stored (interrupt generated, DN flag set, the MDLC0 to MDLC3 bits updated, and recorded to the receive history list).

| MT2 | MT1          | MTO | Message buffer type setting bit          |
|-----|--------------|-----|------------------------------------------|
| 0   | 0            | 0   | Transmit message buffer                  |
| 0   | 0            | 1   | Receive message buffer (no mask setting) |
| 0   | 1            | 0   | Receive message buffer (mask 1 set)      |
| 0   | 1            | 1   | Receive message buffer (mask 2 set)      |
| 1   | 0            | 0   | Receive message buffer (mask 3 set)      |
| 1   | 0            | 1   | Receive message buffer (mask 4 set)      |
| Ot  | her than abo | ve  | Setting prohibited                       |



| MA0 | Message buffer assignment bit |
|-----|-------------------------------|
| 0   | Message buffer not used.      |
| 1   | Message buffer used.          |

Caution Be sure to write 0 to bits 2 and 1.



#### (22) CnMIDLm, CnMIDHm - CANn message ID register m

The CnMIDLm and CnMIDHm registers are used to set an identifier (ID).

Access These registers can be read/written in 16-bit units.

Address Refer to "CAN registers overview" on page 395.

Initial Value Undefined.

#### CnMIDLm

| 15   | 14   | 13   | 12   | 11   | 10   | 9   | 8   |
|------|------|------|------|------|------|-----|-----|
| ID15 | ID14 | ID13 | ID12 | ID11 | ID10 | ID9 | ID8 |
| 7    | 6    | 5    | 4    | 3    | 2    | 1   | 0   |
| ID7  | ID6  | ID5  | ID4  | ID3  | ID2  | ID1 | ID0 |

CnMIDHm

| 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    |
|------|------|------|------|------|------|------|------|
| IDE  | 0    | 0    | ID28 | ID27 | ID26 | ID25 | ID24 |
| 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| ID23 | ID22 | ID21 | ID20 | ID19 | ID18 | ID17 | ID16 |

| IDE | Format mode specification bit                             |  |
|-----|-----------------------------------------------------------|--|
| 0   | Standard format mode (ID28 to ID18: 11 bits) <sup>a</sup> |  |
| 1   | Extended format mode (ID28 to ID0: 29 bits)               |  |
|     |                                                           |  |

a) The ID17 to ID0 bits are not used.

| ID28 to ID0  | Message ID                                  |
|--------------|---------------------------------------------|
| ID28 to ID18 | Standard ID value of 11 bits (when IDE = 0) |
| ID28 to ID0  | Extended ID value of 29 bits (when IDE = 1) |

Caution

1. Be sure to write 0 to bits 14 and 13 of the CnMIDHm register.

2. Be sure to align the ID value according to the given bit positions into this registers. Note that for standard ID, the ID value must be shifted to fit into ID28 to ID11 bit positions.



#### CnMCTRLm - CANn message control register m (23)

The CnMCTRLm register is used to control the operation of the message buffer.

Access This register can be read/written in 16-bit units.

Address Refer to "CAN registers overview" on page 395.

Initial Value  $00 x 0 \ 0000 \ 0000 \ 0000_{\text{B}}.$  The register is initialized by any reset.

#### (a) CnMCTRLm read

| 15 | 14 | 13  | 12  | 11 | 10 | 9   | 8   |
|----|----|-----|-----|----|----|-----|-----|
| 0  | 0  | MUC | 0   | 0  | 0  | 0   | 0   |
| 7  | 6  | 5   | 4   | 3  | 2  | 1   | 0   |
| 0  | 0  | 0   | MOW | IE | DN | TRQ | RDY |

| MUC <sup>a</sup> | Bit indicating that message buffer data is being updated                     |  |  |
|------------------|------------------------------------------------------------------------------|--|--|
| 0                | The CAN module is not updating the message buffer (reception and storage).   |  |  |
| 1                | The CAN module is updating the message buffer (reception and storage).       |  |  |
| a) The M         | The MLIC bit is undefined until the first recention and storage is performed |  |  |

The MUC bit is undefined until the first reception and storage is performed.

| MOW <sup>a</sup> | Message buffer overwrite status bit                                   |
|------------------|-----------------------------------------------------------------------|
| 0                | The message buffer is not overwritten by a newly received data frame. |
| 1                | The message buffer is overwritten by a newly received data frame.     |
| -)               |                                                                       |

a) The MOW bit is not set to 1 even if a remote frame is received and stored in the transmit message buffer with the DN bit = 1.

| IE | Message buffer interrupt request enable bit                                                                                                                                 |
|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0  | Receive message buffer: Valid message reception completion interrupt<br>disabled.<br>Transmit message buffer: Normal message transmission completion<br>interrupt disabled. |
| 1  | Receive message buffer: Valid message reception completion interrupt<br>enabled.<br>Transmit message buffer: Normal message transmission completion<br>interrupt enabled.   |

| DN | Message buffer data update bit                                    |
|----|-------------------------------------------------------------------|
| 0  | A data frame or remote frame is not stored in the message buffer. |
| 1  | A data frame or remote frame is stored in the message buffer.     |



| TRQ | Message buffer transmission request bit                                                                   |
|-----|-----------------------------------------------------------------------------------------------------------|
| 0   | No message frame transmitting request that is pending or being transmitted is in the message buffer.      |
| 1   | The message buffer is holding transmission of a message frame pending or is transmitting a message frame. |

| RDY | Message buffer ready bit                                                                                                                                     |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | The message buffer can be written by software. The CAN module cannot write to the message buffer.                                                            |
| 1   | Writing the message buffer by software is ignored (except a write access to the RDY, TRQ, DN, and MOW bits). The CAN module can write to the message buffer. |

# (b) CnMCTRLm write

| 15 | 14 | 13 | 12           | 11          | 10          | 9            | 8            |
|----|----|----|--------------|-------------|-------------|--------------|--------------|
| 0  | 0  | 0  | 0            | Set<br>IE   | 0           | Set<br>TRQ   | Set<br>RDY   |
| 7  | 6  | 5  | 4            | 3           | 2           | 1            | 0            |
| 0  | 0  | 0  | Clear<br>MOW | Clear<br>IE | Clear<br>DN | Clear<br>TRQ | Clear<br>RDY |

| Clear MOW | Setting of MOW bit       |  |  |  |
|-----------|--------------------------|--|--|--|
| 0         | MOW bit is not changed.  |  |  |  |
| 1         | MOW bit is cleared to 0. |  |  |  |

| Set IE           | Clear IE | Setting of IE bit       |
|------------------|----------|-------------------------|
| 0                | 1        | IE bit is cleared to 0. |
| 1                | 0        | IE bit is set to 1.     |
| Other than above |          | IE bit is not changed.  |

| Clear DN | Setting of DN bit       |
|----------|-------------------------|
| 1        | DN bit is cleared to 0. |
| 0        | DN bit is not changed.  |

| Set TRQ          | Clear TRQ | Setting of TRQ bit       |
|------------------|-----------|--------------------------|
| 0                | 1         | TRQ bit is cleared to 0. |
| 1                | 0         | TRQ bit is set to 1.     |
| Other than above |           | TRQ bit is not changed.  |



| Set RDY          | Clear RDY | Setting of RDY bit       |
|------------------|-----------|--------------------------|
| 0                | 1         | RDY bit is cleared to 0. |
| 1                | 0         | RDY bit is set to 1.     |
| Other than above |           | RDY bit is not changed.  |

Caution 1. Set IE bit and RDY bit always separately.

- 2. Do not set the DN bit to 1 by software. Be sure to write 0 to bit 10.
- 3. Do not set the TRQ bit and the RDY bit (1) at the same time. Set the RDY bit (1) before setting the TRQ bit.
- **4.** Do not clear the RDY bit (0) during message transmission. Follow the transmission abort process about clearing the RDY bit (0) for redefinition of the message buffer.
- 5. Clear again when RDY bit is not cleared even if this bit is cleared.
- 6. Be sure that RDY is cleared before writing to the other message buffer registers, by checking the status of the RDY bit.



# 14.8 CAN Controller Initialization

# 14.8.1 Initialization of CAN module

Before CAN module operation is enabled, the CAN module system clock needs to be determined by setting the CCP[3:0] bits of the CnGMCS register by software. Do not change the setting of the CAN module system clock after CAN module operation is enabled.

The CAN module is enabled by setting the GOM bit of the CnGMCTRL register.

For the procedure of initializing the CAN module, refer to *"Operation of CAN Controller" on page 477*.

## 14.8.2 Initialization of message buffer

After the CAN module is enabled, the message buffers contain undefined values. A minimum initialization for all the message buffers, even for those not used in the application, is necessary before switching the CAN module from the initialization mode to one of the operation modes.

- Clear the RDY, TRQ, and DN bits of all CnMCTRLm registers to 0.
- Clear the MA0 bit of all CnMCONFm registers to 0.

## 14.8.3 Redefinition of message buffer

Redefining a message buffer means changing the ID and control information of the message buffer while a message is being received or transmitted, without affecting other transmission/reception operations.

#### (1) To redefine message buffer in initialization mode

Place the CAN module in the initialization mode once and then change the ID and control information of the message buffer in the initialization mode. After changing the ID and control information, set the CAN module to an operation mode.

#### (2) To redefine message buffer during reception

Perform redefinition as shown in *Figure 14-38*.

#### (3) To redefine message buffer during transmission

To rewrite the contents of a transmit message buffer to which a transmission request has been set, perform transmission abort processing (see *"Transmission abort process except for in normal operation mode with automatic block transmission (ABT)" on page 456* and *"Transmission abort process except for ABT transmission in normal operation mode with automatic block transmission (ABT)" on page 456*. Confirm that transmission has been aborted or completed, and then redefine the message buffer. After redefining



the transmit message buffer, set a transmission request using the procedure described below. When setting a transmission request to a message buffer that has been redefined without aborting the transmission in progress, however, the 1-bit wait time is not necessary.



Figure 14-26 Setting transmission request (TRQ) to transmit message buffer after redefinition

- **Caution** 1. When a message is received, reception filtering is performed in accordance with the ID and mask set to each receive message buffer. If the procedure in Figure 14-38 on page 480 is not observed, the contents of the message buffer after it has been redefined may contradict the result of reception (result of reception filtering). If this happens, check that the ID and IDE received first and stored in the message buffer following redefinition are those stored after the message buffer has been redefined. If no ID and IDE are stored after redefinition, redefine the message buffer again.
  - 2. When a message is transmitted, the transmission priority is checked in accordance with the ID, IDE, and RTR bits set to each transmit message buffer to which a transmission request was set. The transmit message buffer having the highest priority is selected for transmission. If the procedure in Figure 14-26 on page 439 is not observed, a message with an ID not having the highest priority may be transmitted after redefinition.



#### 14.8.4 Transition from initialization mode to operation mode

The CAN module can be switched to the following operation modes.

- Normal operation mode
- · Normal operation mode with ABT
- · Receive-only mode
- · Single-shot mode
- Self-test mode



Figure 14-27 Transition to operation modes

The transition from the initialization mode to an operation mode is controlled by the bit string OPMODE[2:0] in the CnCTRL register.

Changing from one operation mode into another requires shifting to the initialization mode in between. Do not change one operation mode to another directly; otherwise the operation will not be guaranteed.

Requests for transition from an operation mode to the initialization mode are held pending when the CAN bus is not in the interframe space (i.e., frame reception or transmission is in progress), and the CAN module enters the initialization mode at the first bit in the interframe space (the values of the OPMODE[2:0] bits are changed to  $000_{B}$ ). After issuing a request to change the mode to the initialization mode, read the OPMODE[2:0] bits until their value becomes  $000_{B}$  to confirm that the module has entered the initialization mode (see *Figure 14-36 on page 478*).



# 14.8.5 Resetting error counter CnERC of CAN module

If it is necessary to reset the CAN module error counter CnERC and CAN module information register CnINFO when re-initialization or forced recovery from the bus-off status is made, set the CCERC bit of the CnCTRL register to 1 in the initialization mode. When this bit is set to 1, the CnERC and CnINFO registers are cleared to their default values.



# 14.9 Message Reception

## 14.9.1 Message reception

In all the operation modes, the complete message buffer area is analyzed to find a suitable buffer to store a newly received message. All message buffers satisfying the following conditions are included in that evaluation (RX-search process).

- Used as a message buffer (MA0 bit of CnMCONFm register set to 1.)
- Set as a receive message buffer (MT[2:0] bits of CnMCONFm register are set to 001<sub>B</sub>, 010<sub>B</sub>, 011<sub>B</sub>, 100<sub>B</sub>, or 101<sub>B</sub>.)
- Ready for reception (RDY bit of CnMCTRLm register is set to 1.)

When two or more message buffers of the CAN module receive a message, the message is stored according to the priority explained below. The message is always stored in the message buffer with the highest priority, not in a message buffer with a low priority. For example, when an unmasked receive message buffer and a receive message buffer linked to mask 1 have the same ID, the received message is not stored in the message buffer linked to mask 1, even if that message buffer has not received a message and a message has already been received in the unmasked receive message buffer. In other words, when a condition has been set in two or more message buffers with different priorities, the message buffer with the highest priority always stores the message; the message is not stored in message buffers with a lower priority. This also applies when the message buffer with the highest priority is unable to store a message (i.e., when DN = 1 indicating that a message has already been received, but rewriting is disabled because OWS = 0). In this case, the message is not actually stored in the candidate message buffer with the highest priority, but neither is it stored in a message buffer with a lower priority.

| Priority | Storing condition if same ID is set |                            |
|----------|-------------------------------------|----------------------------|
| 1 (high) | Unmasked message buffer             | DN bit = 0                 |
|          |                                     | DN bit = 1 and OWS bit = 1 |
| 2        | Message buffer linked to mask 1     | DN bit = 0                 |
|          |                                     | DN bit = 1 and OWS bit = 1 |
| 3        | Message buffer linked to mask 2     | DN bit = 0                 |
|          |                                     | DN bit = 1 and OWS bit = 1 |
| 4        | Message buffer linked to mask 3     | DN bit = 0                 |
|          |                                     | DN bit = 1 and OWS bit = 1 |
| 5 (low)  | Message buffer linked to mask 4     | DN bit = 0                 |
|          |                                     | DN bit = 1 and OWS bit = 1 |

#### Table 14-24 MBRB priorities



## 14.9.2 Receive data read

To keep data consistency when reading CAN message buffers, perform the data reading according to *Figure 14-49 on page 493* to *Figure 14-52 on page 497*.

During message reception, the CAN module sets DN of the CnMCTRLm register two times: at the beginning of the storage process of data to the message buffer, and again at the end of this storage process. During this storage process, the MUC bit of the CnMCTRLm register of the message buffer is set. (Refer to *Figure 14-28 on page 443*.)

The receive history list is also updated just before the storgage process. In addition, during storage process (MUC = 1), the RDY bit of the CnMCTRL register of the message buffer is locked to avoid the coincidental data WR by CPU. Note the storage process may be disturbed (delayed) when the CPU accesses the message buffer.



Figure 14-28 DN and MUC bit setting period (for standard ID format)

Note If a message shall be stored in a message buffer, the DN bit of this buffer must be cleared before the Message Search Process is started, i.e., right after the ID of the frame is on the bus. In worst case, this happens 15 CAN bits after EOF of the previous frame. Consider to use more than one Message Buffer for reception of a frame, if CAN frames are appearing back-to-back on the bus and none shall be lost.



#### 14.9.3 Receive history list function

The receive history list (RHL) function records in the receive history list the number of the receive message buffer in which each data frame or remote frame was received and stored. The RHL consists of storage elements equivalent to up to 23 messages, the last in-message pointer (LIPT) with the corresponding CnLIPT register and the receive history list get pointer (RGPT) with the corresponding CnRGPT register.

The RHL is undefined immediately after the transition of the CAN module from the initialization mode to one of the operation modes.

The CnLIPT register holds the contents of the RHL element indicated by the value of the LIPT pointer minus 1. By reading the CnLIPT register, therefore, the number of the message buffer that received and stored a data frame or remote frame first can be checked. The LIPT pointer is utilized as a write pointer that indicates to what part of the RHL a message buffer number is recorded. Any time a data frame or remote frame is received and stored, the corresponding message buffer number is recorded to the RHL element indicated by the LIPT pointer. Each time recording to the RHL has been completed, the LIPT pointer is automatically incremented. In this way, the number of the message buffer that has received and stored a frame will be recorded chronologically.

The RGPT pointer is utilized as a read pointer that reads a recorded message buffer number from the RHL. This pointer indicates the first RHL element that the CPU has not read yet. By reading the CnRGPT register by software, the number of a message buffer that has received and stored a data frame or remote frame can be read. Each time a message buffer number is read from the CnRGPT register, the RGPT pointer is automatically incremented.

If the value of the RGPT pointer matches the value of the LIPT pointer, the RHPM bit (receive history list pointer match) of the CnRGPT register is set to 1. This indicates that no message buffer number that has not been read remains in the RHL. If a new message buffer number is recorded, the LIPT pointer is incremented and because its value no longer matches the value of the RGPT pointer, the RHPM bit is cleared. In other words, the numbers of the unread message buffers exist in the RHL.

If the LIPT pointer is incremented and matches the value of the RGPT pointer minus 1, the ROVF bit (receive history list overflow) of the CnRGPT register is set to 1. This indicates that the RHL is full of numbers of message buffers that have not been read. When further message reception and storing occur, the last recorded message buffer number is overwritten by the number of the message buffer that received and stored the newly received message. In this case, after the ROVF bit has been set (1), the recorded message buffer numbers in the RHL do not completely reflect the chronological order. However messages itself are not lost and can be located by CPU search in message buffer memory with the help of the DN-bit.

**Caution** If the history list is in the overflow condition (ROVF is set), reading the history list contents is still possible, until the history list is empty (indicated by RHPM flag set). Nevertheless, the history list remains in the overflow condition, until ROVF is cleared by software. If ROVF is not cleared, the RHPM flag will also not be updated (cleared) upon a message storage of newly received frame. This may lead to the situation, that RHPM indicates an empty history list, although a reception has taken place, while the history list is in the overflow state (ROVF and RHPM are set).



As long as the RHL contains 23 or less entries the sequence of occurrence is maintained. If more receptions occur without reading the RHL by the host processor, complete sequence of receptions can not be recovered.



Figure 14-29 Receive history list



#### 14.9.4 Mask function

For any message buffer, which is used for reception, the assignment to one of four global reception masks (or no mask) can be selected.

By using the mask function, the message ID comparison can be reduced by masked bits, herewith allowing the reception of several different IDs into one buffer.

While the mask function is in effect, an identifier bit that is defined to be 1 by a mask in the received message is not compared with the corresponding identifier bit in the message buffer.

However, this comparison is performed for any bit whose value is defined as 0 by the mask.

For example, let us assume that all messages that have a standard-format ID, in which bits ID27 to ID25 are 0 and bits ID24 and ID22 are 1, are to be stored in message buffer 14. The procedure for this example is shown below.

#### 1. Identifier to be stored in message buffer

| ID28 | ID27 | ID26 | ID25 | ID24 | ID23 | ID22 | ID21 | ID20 | ID19 | ID18 |
|------|------|------|------|------|------|------|------|------|------|------|
| х    | 0    | 0    | 0    | 1    | х    | 1    | х    | х    | х    | х    |

# 2. Identifier to be configured in message buffer 14 (example) (Using CnMIDL14 and CnMIDH14 registers)

| ID28 | ID27 | ID26 | ID25 | ID24 | ID23 | ID22 | ID21 | ID20 | ID19 | ID18 |
|------|------|------|------|------|------|------|------|------|------|------|
| х    | 0    | 0    | 0    | 1    | х    | 1    | х    | х    | х    | х    |
| ID17 | ID16 | ID15 | ID14 | ID13 | ID12 | ID11 | ID10 | ID9  | ID8  | ID7  |
| х    | х    | х    | х    | х    | х    | х    | х    | х    | х    | х    |
| ID6  | ID5  | ID4  | ID3  | ID2  | ID1  | ID0  |      |      |      |      |
| х    | х    | х    | х    | х    | х    | х    |      |      |      |      |

- Note 1. ID with the ID27 to ID25 bits cleared to 0 and the ID24 and ID22 bits set to 1 is registered (initialized) to message buffer 14.
  - Message buffer 14 is set as a standard format identifier that is linked to mask 1 (MT[2:0] of CnMCONF14 register are set to 010<sub>B</sub>).

#### Mask setting for CAN module 1 (mask 1) (example) (Using CAN1 address mask 1 registers L and H (C1MASKL1 and C1MASKH1))

| CMID28 | CMID27 | CMID26 | CMID25 | CMID24 | CMID23 | CMID22 | CMID21 | CMID20 | CMID19 | CMID18 |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| 1      | 0      | 0      | 0      | 0      | 1      | 0      | 1      | 1      | 1      | 1      |
| CMID17 | CMID16 | CMID15 | CMID14 | CMID13 | CMID12 | CMID11 | CMID10 | CMID9  | CMID8  | CMID7  |
| 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      |
| CMID6  | CMID5  | CMID4  | CMID3  | CMID2  | CMID1  | CMIDO  |        |        |        |        |
| 1      | 1      | 1      | 1      | 1      | 1      | 1      |        |        |        |        |

- 1: Not compared (masked)
- 0: Compared



The CMID27 to CMID24 and CMID22 bits are cleared to 0, and the CMID28, CMID23, and CMID21 to CMID0 bits are set to 1.



#### 14.9.5 Multi buffer receive block function

The multi buffer receive block (MBRB) function is used to store a block of data in two or more message buffers sequentially with no CPU interaction, by setting the same ID to two or more message buffers with the same message buffer type. These message buffers can be allocated anywhere in the message buffer memory, they do not even have to follow each other adjacently.

Suppose, for example, the same message buffer type is set to 10 message buffers, message buffers 10 to 19, and the same ID is set to each message buffer. If the first message whose ID matches an ID of the message buffers is received, it is stored in message buffer 10. At this point, the DN bit of message buffer 10 is set, prohibiting overwriting the message buffer when subsequent messages are received.

When the next message with a matching ID is received, it is received and stored in message buffer 11. Each time a message with a matching ID is received, it is sequentially (in the ascending order) stored in message buffers 12, 13, and so on. Even when a data block consisting of multiple messages is received, the messages can be stored and received without overwriting the previously received matching-ID data.

Whether a data block has been received and stored can be checked by setting the IE bit of the CnMCTRLm register of each message buffer. For example, if a data block consists of k messages, k message buffers are initialized for reception of the data block. The IE bit in message buffers 0 to (k-2) is cleared to 0 (interrupts disabled), and the IE bit in message buffer k-1 is set to 1 (interrupts enabled). In this case, a reception completion interrupt occurs when a message has been received and stored in message buffer k-1, indicating that MBRB has become full. Alternatively, by clearing the IE bit of message buffers 0 to (k-3) and setting the IE bit of message buffer k-2, a warning that MBRB is about to overflow can be issued.

The basic conditions of storing receive data in each message buffer for the MBRB are the same as the conditions of storing data in a single message buffer.

- Caution 1. MBRB can be configured for each of the same message buffer types. Therefore, even if a message buffer of another MBRB whose ID matches but whose message buffer type is different has a vacancy, the received message is not stored in that message buffer, but instead discarded.
  - 2. MBRB does not have a ring buffer structure. Therefore, after a message is stored in the message buffer having the highest number in the MBRB configuration, a newly received message will not be stored in the message buffer having the lowest message buffer number.
  - MBRB operates based on the reception and storage conditions; there are no settings dedicated to MBRB, such as function enable bits. By setting the same message buffer type and ID to two or more message buffers, MBRB is automatically configured.
  - 4. With MBRB, "matching ID" means "matching ID after mask". Even if the ID set to each message buffer is not the same, if the ID that is masked by the mask register matches, it is considered a matching ID and the buffer that has this ID is treated as the storage destination of a message.
  - 5. The priority between MBRBs is mentioned in the table Table 14-24.



#### 14.9.6 Remote frame reception

In all the operation modes, when a remote frame is received, the message buffer that is to store the remote frame is searched from all the message buffers satisfying the following conditions.

- Used as a message buffer (MA0 bit of CnMCONFm register set to 1.)
- Set as a transmit message buffer (MT[2:0] bits in CnMCONFm register set to 000<sub>B</sub>)
- Ready for reception (RDY bit of CnMCTRLm register set to 1.)
- Set to transmit message (RTR bit of CnMCONFm register is cleared to 0.)
- Transmission request is not set. (TRQ bit of CnMCTRLm register is cleared to 0.)

Upon acceptance of a remote frame, the following actions are executed if the ID of the received remote frame matches the ID of a message buffer that satisfies the above conditions.

- The DLC[3:0] bit string in the CnMDLCm register store the received DLC value.
- The CnMDATA0m to CnMDATA7m registers in the data area are not updated (data before reception is saved).
- The DN bit of the CnMCTRLm register is set to 1.
- The CINTS1 bit of the CnINTS register is set to 1 (if the IE bit in the CnMCTRLm register of the message buffer that receives and stores the frame is set to 1).
- The receive completion interrupt (INTCnREC) is output (if the IE bit of the message buffer that receives and stores the frame is set to 1 and if the CIE1 bit of the CnIE register is set to 1).
- The message buffer number is recorded in the receive history list.

Caution When a message buffer is searched for receiving and storing a remote frame, overwrite control by the OWS bit of the CnMCONFm register of the message buffer and the DN bit of the CnMCTRLm register are not checked. The setting of OWS is ignored, and DN is set in any case. If more than one transmit message buffer has the same ID and the ID of the received remote frame matches that ID, the remote frame is stored in the transmit message buffer with the lowest message buffer number.



# 14.10 Message Transmission

### 14.10.1 Message transmission

A message buffer with its TRQ bit set to 1 participates in the search for the most high-prioritized message when the following conditions are fulfilled. This behavior is valid for all operational modes.

- Used as a message buffer (MA0 bit of CnMCONFm register set to 1.)
- Set as a transmit message buffer (MT[2:0] bits of CnMCONFm register set to 000<sub>B</sub>.)
- Ready for transmission (RDY bit of CnMCTRLm register set to 1.)

The CAN system is a multi-master communication system. In a system like this, the priority of message transmission is determined based on message identifiers (IDs). To facilitate transmission processing by software when there are several messages awaiting transmission, the CAN module uses hardware to check the ID of the message with the highest priority and automatically identifies that message. This eliminates the need for software-based priority control.

Transmission priority is controlled by the identifier (ID).



#### Figure 14-30 Message processing example

After the transmit message search, the transmit message with the highest priority of the transmit message buffers that have a pending transmission request (message buffers with the TRQ bit set to 1 in advance) is transmitted.

If a new transmission request is set, the transmit message buffer with the new transmission request is compared with the transmit message buffer with a pending transmission request. If the new transmission request has a higher priority, it is transmitted, unless transmission of a message with a low priority has already started. If transmission of a message with a low priority has already started, however, the new transmission request is transmitted later. To solve this priority inversion effect, the software can perform a transmission abort request for the lower priority message. The highest priority is determined according to the following rules.



| Priority | Conditions                                                                                                                                                                                                                                                 | Description                                                                                                                                                                                                                                                                                                        |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 (high) | Value of first 11 bits of ID<br>[ID28 to ID18]:                                                                                                                                                                                                            | The message frame with the lowest value represented by the first 11 bits of the ID is transmitted first. If the value of an 11-bit standard ID is equal to or smaller than the first 11 bits of a 29-bit extended ID, the 11-bit standard ID has a higher priority than a message frame with a 29-bit extended ID. |
| 2        | Frame type                                                                                                                                                                                                                                                 | A data frame with an 11-bit standard ID (RTR bit is cleared to 0) has a higher priority than a remote frame with a standard ID and a message frame with an extended ID.                                                                                                                                            |
| 3        | ID type                                                                                                                                                                                                                                                    | A message frame with a standard ID (IDE bit is cleared to 0) has a higher priority than a message frame with an extended ID.                                                                                                                                                                                       |
| 4        | 4 Value of lower 18 bits of ID<br>[ID17 to ID0]: If one or more transmission-pending extended<br>equal values in the first 11 bits of the ID and the<br>RTR bit values), the message frame with the lo<br>18 bits of its extended ID is transmitted first. |                                                                                                                                                                                                                                                                                                                    |
| 5 (low)  | Message buffer number                                                                                                                                                                                                                                      | If two or more message buffers request transmission of message<br>frames with the same ID, the message from the message buffer with the<br>lowest message buffer number is transmitted first.                                                                                                                      |

Note 1. If the automatic block transmission request bit ABTTRG is set to 1 in the normal operation mode with ABT, the TRQ bit is set to 1 only for one message buffer in the ABT message buffer group.

If the ABT mode was triggered by ABTTRG bit (1), one TRQ bit is set to 1 in the ABT area (buffer 0 through 7). Beyond this TRQ bit, the application can request transmissions (set TRQ bit to 1) for other TX-message buffers that do not belong to the ABT area. In that case an interval arbitration process (TX-search) evaluates all TX-message buffers with TRQ bit set to 1 and chooses the message buffer that contains the highest prioritized identifier for the next transmission. If there are 2 or more identifiers that have the highest priority (i.e. identical identifiers), the message located at the lowest message buffer number is transmitted at first.

Upon successful transmission of a message frame, the following operations are performed.

- The TRQ flag of the corresponding transmit message buffer is automatically cleared to 0.
- The transmission completion status bit CINTS0 of the CnINTS register is set to 1 (if the interrupt enable bit (IE) of the corresponding transmit message buffer is set to 1).
- An interrupt request signal INTCnTRX is output (if the CIE0 bit of the CnIE register is set to 1 and if the interrupt enable bit (IE) of the corresponding transmit message buffer is set to 1).
- 2. When changing the contents of a transmit buffer, the RDY flag of this buffer must be cleared before updating the buffer contents. As during internal transfer actions, the RDY flag may be locked temporarily, the status of RDY must be checked by software, after changing it.



### 14.10.2 Transmit history list function

The transmit history list (THL) function records in the transmit history list the number of the transmit message buffer from which data or remote frames have been were sent. The THL consists of storage elements equivalent to up to seven messages, the last out-message pointer (LOPT) with the corresponding CnLOPT register, and the transmit history list get pointer (TGPT) with the corresponding CnTGPT register.

The THL is undefined immediately after the transition of the CAN module from the initialization mode to one of the operation modes.

The CnLOPT register holds the contents of the THL element indicated by the value of the LOPT pointer minus 1. By reading the CnLOPT register, therefore, the number of the message buffer that transmitted a data frame or remote frame first can be checked. The LOPT pointer is utilized as a write pointer that indicates to what part of the THL a message buffer number is recorded. Any time a data frame or remote frame is transmitted, the corresponding message buffer number is recorded to the THL element indicated by the LOPT pointer. Each time recording to the THL has been completed, the LOPT pointer is automatically incremented. In this way, the number of the message buffer that has received and stored a frame will be recorded chronologically.

The TGPT pointer is utilized as a read pointer that reads a recorded message buffer number from the THL. This pointer indicates the first THL element that the CPU has not yet read. By reading the CnTGPT register by software, the number of a message buffer that has completed transmission can be read. Each time a message buffer number is read from the CnTGPT register, the TGPT pointer is automatically incremented.

If the value of the TGPT pointer matches the value of the LOPT pointer, the THPM bit (transmit history list pointer match) of the CnTGPT register is set to 1. This indicates that no message buffer numbers that have not been read remain in the THL. If a new message buffer number is recorded, the LOPT pointer is incremented and because its value no longer matches the value of the TGPT pointer, the THPM bit is cleared. In other words, the numbers of the unread message buffers exist in the THL.

If the LOPT pointer is incremented and matches the value of the TGPT pointer minus 1, the TOVF bit (transmit history list overflow) of the CnTGPT register is set to 1. This indicates that the THL is full of message buffer numbers that have not been read. If a new message is received and stored, the message buffer number recorded last is overwritten by the message buffer number that transmitted its message afterwards. In this case, after the TOVF bit has been set (1), therefore, the recorded message buffer numbers in the THL do not completely reflect the chronological order. However the other transmitted message buffers unless the CPU has not overwritten a transmit object in one of these buffers beforehand. In total up to six transmission completions can occur without overflowing the THL.



**Caution** If the history list is in the overflow condition (TOVF is set), reading the history list contents is still possible, until the history list is empty (indicated by THPM flag set). Nevertheless, the history list remains in the overflow condition, until TOVF is cleared by software. If TOVF is not cleared, the THPM flag will also not be updated (cleared) upon successful transmission of a new message. This may lead to the situation, that THPM indicates an empty history list, although a successful transmission has taken place, while the history list is in the overflow state (TOVF and THPM are set).



Figure 14-31 Transmit history list



#### 14.10.3 Automatic block transmission (ABT)

The automatic block transmission (ABT) function is used to transmit two or more data frames successively with no CPU interaction. The maximum number of transmit message buffers assigned to the ABT function is eight (message buffer numbers 0 to 7).

By setting the OPMODE[2:0] bits of the CnCTRL register to  $010_B$ , "normal operation mode with automatic block transmission function" (hereafter referred to as ABT mode) can be selected.

To issue an ABT transmission request, define the message buffers by software first. Set the MA0 bit (1) in all the message buffers used for ABT, and define all the buffers as transmit message buffers by setting the MA[2:0] bits to  $000_B$ . Be sure to set the same ID for the message buffers for ABT even when that ID is being used for all the message buffers. To use two or more IDs, set the ID of each message buffer by using the CnMIDLm and CnMIDHm registers. Set the CnMDLCm and CnMDATA0m to CnMDATA7m registers before issuing a transmission request for the ABT function.

After initialization of message buffers for ABT is finished, the RDY bit needs to be set (1). In the ABT mode, the TRQ bit does not have to be manipulated by software.

After the data for the ABT message buffers has been prepared, set the ABTTRG bit to 1. Automatic block transmission is then started. When ABT is started, the TRQ bit in the first message buffer (message buffer 0) is automatically set to 1. After transmission of the data of message buffer 0 is finished, the TRQ bit of the next message buffer, message buffer 1, is set automatically. In this way, transmission is executed successively.

A delay time can be inserted by program in the interval in which the transmission request (TRQ) is automatically set while successive transmission is being executed. The delay time to be inserted is defined by the CnGMABTD register. The unit of the delay time is DBT (data bit time). DBT depends on the setting of the CnBRP and CnBTR registers.

Among transmit objects within the ABT-area, the priority of the transmission ID is not evaluated. The data of message buffers 0 to 7 are sequentially transmitted. When transmission of the data frame from message buffer 7 has been completed, the ABTTRG bit is automatically cleared to 0 and the ABT operation is finished.

If the RDY bit of an ABT message buffer is cleared during ABT, no data frame is transmitted from that buffer, ABT is stopped, and the ABTTRG bit is cleared. After that, transmission can be resumed from the message buffer where ABT stopped, by setting the RDY and ABTTRG bits to 1 by software. To not resume transmission from the message buffer where ABT stopped, the internal ABT engine can be reset by setting the ABTCLR bit to 1 while ABT mode is stopped and the ABTTRG bit is cleared to 0. In this case, transmission is started from message buffer 0 if the ABTCLR bit is cleared to 0 and then the ABTTRG bit is set to 1.

An interrupt can be used to check if data frames have been transmitted from all the message buffers for ABT. To do so, the IE bit of the CnMCTRLm register of each message buffer except the last message buffer needs to be cleared (0).

If a transmit message buffer other than those used by the ABT function (message buffers 8 to 31) is assigned to a transmit message buffer, the message to be transmitted next is determined by the priority of the transmission ID of the ABT message buffer whose transmission is currently



held pending and the transmission ID of the message buffers other than those used by the ABT function.

Transmission of a data frame from an ABT message buffer is not recorded in the transmit history list (THL).

- **Caution 1.** Set the ABTCLR bit to 1 while the ABTTRG bit is cleared to 0 in order to resume ABT operation at buffer No.0. If the ABTCLR bit is set to 1 while the ABTTRG bit is set to 1, the subsequent operation is not guaranteed.
  - 2. If the automatic block transmission engine is cleared by setting the ABTCLR bit to 1, the ABTCLR bit is automatically cleared immediately after the processing of the clearing request is completed.
  - **3.** Do not set the ABTTRG bit in the initialization mode. If the ABTTRG bit is set in the initialization mode, the proper operation is not guaranteed after the mode is changed from the initialization mode to the ABT mode.
  - Do not set the TRQ bit of the ABT message buffers to 1 by software in the normal operation mode with ABT. Otherwise, the operation is not guaranteed.
  - 5. The CnGMABTD register is used to set the delay time that is inserted in the period from completion of the preceding ABT message to setting of the TRQ bit for the next ABT message when the transmission requests are set in the order of message numbers for each message for ABT that is successively transmitted in the ABT mode. The timing at which the messages are actually transmitted onto the CAN bus varies depending on the status of transmission from other stations and the status of the setting of the transmission request for messages other than the ABT messages (message buffers 8 to 31).
  - 6. If a transmission request is made for a message other than an ABT message and if no delay time is inserted in the interval in which transmission requests for ABT are automatically set (CnGMABTD register =  $00_H$ ), messages other than ABT messages may be transmitted not depending on their priority compared to the priority of the ABT message.
  - 7. Do not clear the RDY bit to 0 when the ABTTRG bit = 1.
  - If a message is received from another node while normal operation mode with ABT is active, the TX-message from the ABT-area may be transmitted with delay of one frame although CnGMABTD register was set up with 00<sub>H</sub>.



### 14.10.4 Transmission abort process

# (1) Transmission abort process except for in normal operation mode with automatic block transmission (ABT)

The user can clear the TRQ bit of the CnMCTRLm register to 0 to abort a transmission request. The TRQ bit will be cleared immediately if the abort was successful. Whether the transmission was successfully aborted or not can be checked using the TSTAT bit of the CnCTRL register and the CnTGPT register, which indicate the transmission status on the CAN bus (for details, refer to the processing in *Figure 14-45 on page 489*).

# (2) Transmission abort process except for ABT transmission in normal operation mode with automatic block transmission (ABT)

The user can clear the ABTTRG bit of the CnGMABT register to 0 to abort a transmission request. After checking the ABTTRG bit of the CnGMABT register = 0, clear the TRQ bit of the CnMCTRLm register to 0. The TRQ bit will be cleared immediately if the abort was successful. Whether the transmission was successfully aborted or not can be checked using the TSTAT bit of the CnCTRL register and the CnTGPT register, which indicate the transmission status on the CAN bus (for details, refer to the processing in *Figure 14-46 on page 490*).

# (3) Transmission abort process for ABT transmission in normal operation mode with automatic block transmission (ABT)

To abort ABT that is already started, clear the ABTTRG bit of the CnGMABT register to 0. In this case, the ABTTRG bit remains 1 if an ABT message is currently being transmitted and until the transmission is completed (successfully or not), and is cleared to 0 as soon as transmission is finished. This aborts ABT.

If the last transmission (before ABT) was successful, the normal operation mode with ABT is left with the internal ABT pointer pointing to the next message buffer to be transmitted.

In the case of an erroneous transmission, the position of the internal ABT pointer depends on the status of the TRQ bit in the last transmitted message buffer. If the TRQ bit is set to 1 when clearing the ABTTRG bit is requested, the internal ABT pointer points to the last transmitted message buffer (for details, refer to the process in *Figure 14-47 on page 491*). If the TRQ bit is cleared to 0 when clearing the ABTTRG bit is requested, the internal ABT pointer is incremented (+1) and points to the next message buffer in the ABT area (for details, refer to the process in *Figure 14-48 on page 492*).

**Caution** Be sure to abort ABT by clearing ABTTRG bit to 0. The operation is not guaranteed if aborting transmission is requested by clearing RDY.

When the normal operation mode with ABT is resumed after ABT has been aborted and the ABTTRG bit is set to 1, the next ABT message buffer to be transmitted can be determined from the following table.



| Status of TRQ of<br>ABT message buffer                                                                      | Abort after successful transmission              | Abort after erroneous transmission               |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------|--------------------------------------------------|--------------------------------------------------|--|--|--|--|
| Set (1)                                                                                                     | Next message buffer in the ABT area <sup>a</sup> | Same message buffer in the ABT area              |  |  |  |  |
| Cleared (0)                                                                                                 | Next message buffer in the ABT area <sup>a</sup> | Next message buffer in the ABT area <sup>a</sup> |  |  |  |  |
| a) The above resumption operation can be performed only if a message buffer ready for ABT exists in the ABT |                                                  |                                                  |  |  |  |  |

The above resumption operation can be performed only if a message buffer ready for ABT exists in the ABT area. For example, an abort request that is issued while ABT of message buffer 7 is in progress is regarded as completion of ABT, rather than abort, if transmission of message buffer 7 has been successfully completed, even if the ABTTRG bit is cleared to 0. If the RDY bit in the next message buffer in the ABT area is cleared to 0, the internal ABT pointer is retained, but the resumption operation is not performed even if the ABTTRG bit is set to 1, and ABT ends immediately.

# 14.10.5 Remote frame transmission

Remote frames can be transmitted only from transmit message buffers. Set whether a data frame or remote frame is transmitted via the RTR bit of the CnMCONFm register. Setting (1) the RTR bit sets remote frame transmission.



# 14.11 Power Saving Modes

## 14.11.1 CAN sleep mode

The CAN sleep mode can be used to set the CAN Controller to stand-by mode in order to reduce power consumption. The CAN module can enter the CAN sleep mode from all operation modes. Release of the CAN sleep mode returns the CAN module to exactly the same operation mode from which the CAN sleep mode was entered.

In the CAN sleep mode, the CAN module does not transmit messages, even when transmission requests are issued or pending.

#### (1) Entering CAN sleep mode

The CPU issues a CAN sleep mode transition request by writing  $01_B$  to the PSMODE[1:0] bits of the CnCTRL register.

This transition request is acknowledged only under the following conditions.

- 1. The CAN module is already in one of the following operation modes
  - Normal operation mode
  - Normal operation mode with ABT
  - Receive-only mode
  - Single-shot mode
  - Self-test mode
  - CAN stop mode in all the above operation modes
- 2. The CAN bus state is bus idle (the 4th bit in the interframe space is recessive).

If the CAN bus is fixed to dominant, the request for transition to the CAN sleep mode is held pending. Also the transition from CAN stop mode to CAN sleep mode is independent of the CAN bus state.

- 3. No transmission request is pending
- **Note** If a sleep mode request is pending, and at the same time a message is received in a message box, the sleep mode request is not cancelled, but is executed right after message storage has been finished. This may result in AFCAN being in sleep mode, while the CPU would execute the RX interrupt routine. Therefore, the interrupt routine must check the access to the message buffers as well as reception history list registers by using the MBON flag, if sleep mode is used.

If any one of the conditions mentioned above is not met, the CAN module will operate as follows.

- If the CAN sleep mode is requested from the initialization mode, the CAN sleep mode transition request is ignored and the CAN module remains in the initialization mode.
- If the CAN bus state is not bus idle (i.e., the CAN bus state is either transmitting or receiving) when the CAN sleep mode is requested in one of the operation modes, immediate transition to the CAN sleep mode is not possible. In this case, the CAN sleep mode transition request has to be held pending until the CAN bus state becomes bus idle (the 4th bit in the interframe space is recessive). In the time from the CAN sleep mode request to successful transition, the PSMODE[1:0] bits remain 00<sub>B</sub>. When the module has entered the CAN sleep mode, the PSMODE[1:0] bits are set



to 01<sub>B</sub>.

- If a request for transition to the initialization mode and a request for transition to the CAN sleep mode are made at the same time while the CAN module is in one of the operation modes, the request for the initialization mode is enabled. The CAN module enters the initialization mode at a predetermined timing. At this time, the CAN sleep mode request is not held pending and is ignored.
- Even when initialization mode and sleep mode are not requested simultaneously (i.e the first request has not been granted while the second request is made), the request for initialization has priority over the sleep mode request. The sleep mode request is cancelled when the initialization mode is requested. When a pending request for initialization mode is present, a subsequent request for Sleep mode request is cancelled right at the point in time where it was submitted.

#### (2) Status in CAN sleep mode

The CAN module is in the following state after it enters the CAN sleep mode:

- The internal operating clock is stopped and the power consumption is minimized.
- The function to detect the falling edge of the CAN reception pin (CRXDn) remains in effect to wake up the CAN module from the CAN bus.
- To wake up the CAN module from the CPU, data can be written to the PSMODE[1:0] bits of the CAN module control register (CnCTRL), but nothing can be written to other CAN module registers or bits.
- The CAN module registers can be read, except for the CnLIPT, CnRGPT, CnLOPT, and CnTGPT registers.
- The CAN message buffer registers cannot be written or read.
- MBON bit of the CAN Global Control register (CnGMCTRL) is cleared.
- A request for transition to the initialization mode is not acknowledged and is ignored.



#### (3) Releasing CAN sleep mode

The CAN sleep mode is released by the following events:

- When the CPU writes 00<sub>B</sub> to the PSMODE[1:0] bits of the CnCTRL register
- A falling edge at the CAN reception pin (CRXDn) (i.e. the CAN bus level shifts from recessive to dominant)

**Caution** Even if the falling edge belongs to the SOF of a receive message, this message will not be received and stored. If the CPU has turned off the clock supply to the CAN module while the CAN module was in sleep mode, even subsequently the CAN sleep mode will not be released andPSMODE[1:0] will remain 01<sub>B</sub> unless the clock to the CAN module is supplied again. In addition to this, the receive message will not be received after that.

After releasing the sleep mode, the CAN module returns to the operation mode from which the CAN sleep mode was requested and the PSMODE[1:0] bits of the CnCTRL register must be reset by software to  $00_B$ . If the CAN sleep mode is released by a change in the CAN bus state, the CINTS5 bit of the CnINTS register is set to 1, regardless of the CIE bit of the CnIE register. After the CAN module is released from the CAN sleep mode, it participates in the CAN bus again by automatically detecting 11 consecutive recessive-level bits on the CAN bus. The user application has to wait until MBON = 1, before accessing message buffers again.

When a request for transition to the initialization mode is made while the CAN module is in the CAN sleep mode, that request is ignored; the CAN module has to be released from sleep mode by software first before entering the initialization mode.

#### Caution

1. Be aware that the release of CAN sleep mode by CAN bus event, and thus the wake up interrupt may happen at any time, even right after requesting sleep mode, if a CAN bus event occurs.

- Always reset the PSMODE[1:0] bits to 00<sub>B</sub>, when waking up from CAN sleep mode, before accessing any other registers of the CAN module.
- **3.** Always clear the interrupt flag CINTS5, when waking up from CAN sleep mode.



## 14.11.2 CAN stop mode

The CAN stop mode can be used to set the CAN Controller to stand-by mode to reduce power consumption. The CAN module can enter the CAN stop mode only from the CAN sleep mode. Release of the CAN stop mode puts the CAN module in the CAN sleep mode.

The CAN stop mode can only be released (entering CAN sleep mode) by writing  $01_B$  to the PSMODE[1:0] bits of the CnCTRL register and not by a change in the CAN bus state. No message is transmitted even when transmission requests are issued or pending.

#### (1) Entering CAN stop mode

A CAN stop mode transition request is issued by writing 11<sub>B</sub> to the PSMODE[1:0] bits of the CnCTRL register.

A CAN stop mode request is only acknowledged when the CAN module is in the CAN sleep mode. In all other modes, the request is ignored.

**Caution** To set the CAN module to the CAN stop mode, the module must be in the CAN sleep mode. To confirm that the module is in the sleep mode, check that the PSMODE[1:0] bits =  $01_B$ , and then request the CAN stop mode. If a bus change occurs at the CAN reception pin (CRXDn) while this process is being performed, the CAN sleep mode is automatically released. In this case, the CAN stop mode transition request cannot be acknowledged.

#### (2) Status in CAN stop mode

The CAN module is in the following state after it enters the CAN stop mode.

- The internal operating clock is stopped and the power consumption is minimized.
- To wake up the CAN module from the CPU, data can be written to the PSMODE[1:0] bits of the CAN module control register (CnCTRL), but nothing can be written to other CAN module registers or bits.
- The CAN module registers can be read, except for the CnLIPT, CnRGPT, CnLOPT, and CnTGPT registers.
- The CAN message buffer registers cannot be written or read.
- MBON bit of the CAN Global Control register (CnGMCTRL) is cleared.
- An initialization mode transition request is not acknowledged and is ignored.

#### (3) Releasing CAN stop mode

The CAN stop mode can only be released by writing  $01_B$  to the PSMODE[1:0] bits of the CnCTRL register. After releasing the CAN stop mode, the CAN module enters the CAN sleep mode.

When the initialization mode is requested while the CAN module is in the CAN stop mode, that request is ignored; the CPU has to release the stop mode and subsequently CAN sleep mode before entering the initialization mode. It is impossible to enter the other operation mode directly from the CAN stop mode not entering the CAN sleep mode, that request is ignored.



#### 14.11.3 Example of using power saving modes

In some application systems, it may be necessary to place the CPU in a power saving mode to reduce the power consumption. By using the power saving mode specific to the CAN module and the power saving mode specific to the CPU in combination, the CPU can be woken up from the power saving status by the CAN bus.

Here is an example for using the power saving modes.

- First, put the CAN module in the CAN sleep mode (PSMODE[1:0] = 01<sub>B</sub>). Next, put the CPU in the power saving mode. If an edge transition from recessive to dominant is detected at the CAN reception pin (CRXDn) in this status, the CINTS5 bit in the CAN module is set to 1. If the CIE5 bit of the CnCTRL register is set to 1, a wakeup interrupt (INTWUPn) is generated.
- The CAN module is automatically released from CAN sleep mode (PSMODE = 00<sub>B</sub>) and returns to normal operation mode.
- The CPU, in response to INTWUPn, can release its own power saving mode and return to normal operation mode.

To further reduce the power consumption of the CPU, the internal clock - including that of the CAN module - may be stopped. In this case, the operating clock supplied to the CAN module is stopped after the CAN module has been put in CAN sleep mode. Then the CPU enters a power saving mode in which the clock supplied to the CPU is stopped.

- If an edge transition from recessive to dominant is detected at the CAN reception pin (CRXDn) in this status, the CAN module can set the CINTS5 bit to 1 and generate the wakeup interrupt (INTWUPn) even if it is not supplied with the clock.
- The other functions, however, do not operate, because clock supply to the CAN module is stopped, and the module remains in CAN sleep mode.
- The CPU, in response to INTWUPn
  - releases its power saving mode,
  - resumes supply of the internal clocks including the clock to the CAN module - after the oscillation stabilization time has elapsed, and
  - starts instruction execution.
- The CAN module is immediately released from the CAN sleep mode when clock supply is resumed, and returns to the normal operation mode (PSMODE = 00<sub>B</sub>).



# 14.12 Interrupt Function

The CAN module provides 6 different interrupt sources.

The occurrence of these interrupt sources is stored in interrupt status registers. Four separate interrupt request signals are generated from the six interrupt sources. When an interrupt request signal that corresponds to two or more interrupt sources is generated, the interrupt sources can be identified by using an interrupt status register. After an interrupt source has occurred, the corresponding interrupt status bit must be cleared to 0 by software.

| No. | Interrupt status bit |          | Interrupt enable bit |          | Interrupt         |                                                                |  |  |
|-----|----------------------|----------|----------------------|----------|-------------------|----------------------------------------------------------------|--|--|
|     | Name                 | Register | Name                 | Register | request<br>signal | Interrupt source description                                   |  |  |
| 1   | CINTS0               | CnINTS   | CIE0 <sup>a</sup>    | CnIE     | INTCnTRX          | Message frame successfully transmitted from message buffer m   |  |  |
| 2   | CINTS1               | CnINTS   | CIE1 <sup>a</sup>    | CnIE     | INTCnREC          | Valid message frame reception in message buffer m              |  |  |
| 3   | CINTS2               | CnINTS   | CIE2                 | CnIE     | INTCnERR          | CAN module error state interrupt (Supplement 1)                |  |  |
| 4   | CINTS3               | CnINTS   | CIE3                 | CnIE     |                   | CAN module protocol error interrupt<br>(Supplement 2)          |  |  |
| 5   | CINTS4               | CnINTS   | CIE4                 | CnIE     |                   | CAN module arbitration loss interrupt                          |  |  |
| 6   | CINTS5               | CnINTS   | CIE5                 | CnIE     | INTCnWUP          | CAN module wakeup interrupt from CAN sleep mode (Supplement 3) |  |  |

 Table 14-25
 List of CAN module interrupt sources

<sup>a)</sup> The IE bit (message buffer interrupt enable bit) in the CnMCTRL register of the corresponding message buffer has to be set to 1 for that message buffer to participate in the interrupt generation process.

**Supplements** 1. This interrupt is generated when the transmission/reception error counter is at the warning level, or in the error passive or bus-off state.

- 2. This interrupt is generated when a stuff error, form error, ACK error, bit error, or CRC error occurs.
- 3. This interrupt is generated when the CAN module is woken up from the CAN sleep mode because a falling edge is detected at the CAN reception pin (CAN bus transition from recessive to dominant).



# 14.13 Diagnosis Functions and Special Operational Modes

The CAN module provides a receive-only mode, single-shot mode, and selftest mode to support CAN bus diagnosis functions or the operation of special CAN communication methods.

# 14.13.1 Receive-only mode

The receive-only mode is used to monitor receive messages without causing any interference on the CAN bus and can be used for CAN bus analysis nodes.

For example, this mode can be used for automatic baud-rate detection. The baud rate in the CAN module is changed until "valid reception" is detected, so that the baud rates in the module match ("valid reception" means a message frame has been received in the CAN protocol layer without occurrence of an error and with an appropriate ACK between nodes connected to the CAN bus). A valid reception does not require message frames to be stored in a receive message buffer (data frames) or transmit message buffer (remote frames). The event of valid reception is indicated by setting the VALID bit of the CnCTRL register (1).



#### Figure 14-32 CAN module terminal connection in receive-only mode

In the receive-only mode, no message frames can be transmitted from the CAN module to the CAN bus. Transmit requests issued for message buffers defined as transmit message buffers are held pending.

In the receive-only mode, the CAN transmission pin (CTXDn) in the CAN module is fixed to the recessive level. Therefore, no active error flag can be transmitted from the CAN module to the CAN bus even when a CAN bus error is detected while receiving a message frame. Since no transmission can be issued from the CAN module, the transmission error counter the CnERC.TEC7 to CnERC.TEC0 bits are never updated. Therefore, a CAN module in the receive-only mode does not enter the bus-off state.

Furthermore, in the receive-only mode ACK is not returned to the CAN bus in this mode upon the valid reception of a message frame. Internally, the local



node recognizes that it has transmitted ACK. An overload frame cannot be transmitted to the CAN bus.

**Caution** If only two CAN nodes are connected to the CAN bus and one of them is operating in the receive-only mode, there is no ACK on the CAN bus. Due to the missing ACK, the transmitting node will transmit an active error flag, and repeat transmitting a message frame. The transmitting node becomes error passive after transmitting the message frame 16 times (assuming that the error counter was 0 in the beginning and no other errors have occurred). After the message frame for the 17th time is transmitted, the transmitting node generates a passive error flag. The receiving node in the receive-only mode detects the first valid message frame at this point, and the VALID bit is set to 1 for the first time.

#### 14.13.2 Single-shot mode

In the single-shot mode, automatic re-transmission as defined in the CAN protocol is switched off. (According to the CAN protocol, a message frame transmission that has been aborted by either arbitration loss or error occurrence has to be repeated without control by software.) All other behavior of single shot mode is identical to normal operation mode. Features of single shot mode can not be used in combination with normal mode with ABT.

The single-shot mode disables the re-transmission of an aborted message frame transmission according to the setting of the AL bit of the CnCTRL register. When the AL bit is cleared to 0, re-transmission upon arbitration loss and upon error occurrence is disabled. If the AL bit is set to 1, re-transmission upon error occurrence is disabled, but re-transmission upon arbitration loss is enabled. As a consequence, the TRQ bit in a message buffer defined as a transmit message buffer is cleared to 0 by the following events:

- · Successful transmission of the message frame
- · Arbitration loss while sending the message frame
- · Error occurrence while sending the message frame

The events arbitration loss and error occurrence can be distinguished by checking the CINTS4 and CINTS3 bits of the CnINTS register respectively, and the type of the error can be identified by reading the LEC[2:0] bits of the CnLEC register.

Upon successful transmission of the message frame, the transmit completion interrupt bit CINTS0 of the CnINTS register is set to 1. If the CIE0 bit of the CnIE register is set to 1 at this time, an interrupt request signal is output.

The single-shot mode can be used when emulating time-triggered communication methods (e.g., TTCAN level 1).

**Caution** The AL bit is only valid in single-shot mode. It does not influence the operation of re-transmission upon arbitration loss in the other operation modes.



## 14.13.3 Self-test mode

In the self-test mode, message frame transmission and message frame reception can be tested without connecting the CAN node to the CAN bus or without affecting the CAN bus.

In the self-test mode, the CAN module is completely disconnected from the CAN bus, but transmission and reception are internally looped back. The CAN transmission pin (CTXDn) is fixed to the recessive level.

If the falling edge on the CAN reception pin (CRXDn) is detected after the CAN module has entered the CAN sleep mode from the self-test mode, however, the module is released from the CAN sleep mode in the same manner as the other operation modes. To keep the module in the CAN sleep mode, use the CAN reception pin (CRXDn) as a port pin.



Figure 14-33 CAN module terminal connection in self-test mode



#### 14.13.4 Receive/transmit operation in each operation mode

The following table shows outline of the receive/transmit operation in each operation mode.

| Operation<br>mode                       | Transmis-<br>sion of<br>data/remot<br>e frame | Transmis-<br>sion of<br>ACK | Transmis-<br>sion of<br>error/over<br>load<br>frame | Transmis-<br>sion retry | Automatic<br>block<br>transmis-<br>sion (ABT) | Set of<br>VALID bit | Store data to<br>message<br>buffer |
|-----------------------------------------|-----------------------------------------------|-----------------------------|-----------------------------------------------------|-------------------------|-----------------------------------------------|---------------------|------------------------------------|
| Initialization<br>mode                  | No                                            | No                          | No                                                  | No                      | No                                            | No                  | No                                 |
| Normal<br>operation<br>mode             | Yes                                           | Yes                         | Yes                                                 | Yes                     | No                                            | Yes                 | Yes                                |
| Normal<br>operation<br>mode with<br>ABT | Yes                                           | Yes                         | Yes                                                 | Yes                     | Yes                                           | Yes                 | Yes                                |
| Receive<br>only mode                    | No                                            | No                          | No                                                  | No                      | No                                            | Yes                 | Yes                                |
| Single-shot<br>mode                     | Yes                                           | Yes                         | Yes                                                 | No <sup>a</sup>         | No                                            | Yes                 | Yes                                |
| Self-test<br>mode                       | Yes <sup>b</sup>                              | Yes <sup>b</sup>            | Yes <sup>b</sup>                                    | Yes <sup>b</sup>        | No                                            | Yes <sup>b</sup>    | Yes <sup>b</sup>                   |

 Table 14-26
 Outline of the receive/transmit in each operation mode

a) When the arbitration lost occurs, control of re-transmission is possible by the AL bit of CnCTRL register.

b) Each signals are not generated to outside, but generated into the CAN module.



# 14.14 Time Stamp Function

CAN is an asynchronous, serial protocol. All nodes connected to the CAN bus have a local, autonomous clock. As a consequence, the clocks of the nodes have no relation (i.e., the clocks are asynchronous and may have different frequencies).

In some applications, however, a common time base over the network (= global time base) is needed. In order to build up a global time base, a time stamp function is used. The essential mechanism of a time stamp function is the capture of timer values triggered by signals on the CAN bus.

# 14.14.1 Time stamp function

The CAN Controller supports the capturing of timer values triggered by a specific frame. An on-chip 16-bit capture timer unit in a microcontroller system is used in addition to the CAN Controller. The 16-bit capture timer unit captures the timer value according to a trigger signal (TSOUT) for capturing that is output when a data frame is received from the CAN Controller. The CPU can retrieve the time of occurrence of the capture event, i.e., the time stamp of the message received from the CAN bus, by reading the captured value. The TSOUT signal can be selected from the following two event sources and is specified by the TSSEL bit of the CnTS register.

- SOF event (start of frame) (TSSEL = 0)
- EOF event (last bit of end of frame) (TSSEL = 1)

The TSOUT signal is enabled by setting the TSEN bit of the CnTS register to 1.



Figure 14-34 Timing diagram of capture signal TSOUT

The TSOUT signal toggles its level upon occurrence of the selected event during data frame reception (in *Figure 14-34*, the SOF is used as the trigger event source). To capture a timer value by using the TSOUT signal, the capture timer unit must detect the capture signal at both the rising edge and falling edge.

This time stamp function is controlled by the TSLOCK bit of the CnTS register. When TSLOCK is cleared to 0, the TSOUT signal toggles upon occurrence of the selected event. If TSLOCK is set to 1, the TSOUT signal toggles upon occurrence of the selected event, but the toggle is stopped as the TSEN bit is automatically cleared to 0 as soon as the message storing to the message buffer 0 starts. This suppresses the subsequent toggle occurrence by the TSOUT signal, so that the time stamp value toggled last (= captured last) can be saved as the time stamp value of the time at which the data frame was received in message buffer 0.



Caution The time stamp function using the TSLOCK bit stops toggle of the TSOUT signal by receiving a data frame in message buffer 0. Therefore, message buffer 0 must be set as a receive message buffer. Since a receive message buffer cannot receive a remote frame, toggle of the TSOUT signal cannot be stopped by reception of a remote frame. Toggle of the TSOUT signal does not stop when a data frame is received in a message buffer other than message buffer 0.
 For these reasons, a data frame cannot be received in message buffer 0 when the CAN module is in the normal operation mode with ABT, because message buffer 0 must be set as a transmit message buffer. In this operation mode, therefore, the function to stop toggle of the TSOUT signal by the TSLOCK bit cannot be used.

### 14.15 Baud Rate Settings

### 14.15.1 Baud rate setting conditions

Make sure that the settings are within the range of limit values for ensuring correct operation of the CAN Controller, as follows.

•  $5TQ \le SPT$  (sampling point)  $\le 17 TQ$ 

SPT = TSEG1 + 1

• 8 TQ  $\leq$  DBT (data bit time)  $\leq$  25 TQ

DBT = TSEG1 + TSEG2 + 1TQ = TSEG2 + SPT

- 1 TQ  $\leq$  SJW (synchronization jump width)  $\leq$  4TQ SJW  $\leq$  DBT SPT
- $4 \leq TSEG1 \leq 16$  [ $3 \leq Setting value of TSEG1[3:0] \leq 15$ ]
- $1 \leq TSEG2 \leq 8 \ [0 \leq Setting value of TSEG2[2:0] \leq 7]$

Note 1.  $TQ = 1/f_{TQ}$  (f\_TQ: CAN protocol layer basic system clock)

- 2. TSEG1[3:0] (Bits 3 to 0 of CAN bit rate register (CnBTR))
- 3. TSEG2[2:0] (Bits 10 to 8 of CAN bit rate register (CnBTR))



*Table 14-27* shows the combinations of bit rates that satisfy the above conditions.

|            | Val             |                 | CnBTR register setting value |                   |                |                |                   |
|------------|-----------------|-----------------|------------------------------|-------------------|----------------|----------------|-------------------|
| DBT length | SYNC<br>SEGMENT | PROP<br>SEGMENT | PHASE<br>SEGMENT1            | PHASE<br>SEGMENT2 | TSEG1<br>[3:0] | TSEG2<br>[2:0] | point<br>(unit %) |
| 25         | 1               | 8               | 8                            | 8                 | 1111           | 111            | 68.0              |
| 24         | 1               | 7               | 8                            | 8                 | 1110           | 111            | 66.7              |
| 24         | 1               | 9               | 7                            | 7                 | 1111           | 110            | 70.8              |
| 23         | 1               | 6               | 8                            | 8                 | 1101           | 111            | 65.2              |
| 23         | 1               | 8               | 7                            | 7                 | 1110           | 110            | 69.6              |
| 23         | 1               | 10              | 6                            | 6                 | 1111           | 101            | 73.9              |
| 22         | 1               | 5               | 8                            | 8                 | 1100           | 111            | 63.6              |
| 22         | 1               | 7               | 7                            | 7                 | 1101           | 110            | 68.2              |
| 22         | 1               | 9               | 6                            | 6                 | 1110           | 101            | 72.7              |
| 22         | 1               | 11              | 5                            | 5                 | 1111           | 100            | 77.3              |
| 21         | 1               | 4               | 8                            | 8                 | 1011           | 111            | 61.9              |
| 21         | 1               | 6               | 7                            | 7                 | 1100           | 110            | 66.7              |
| 21         | 1               | 8               | 6                            | 6                 | 1101           | 101            | 71.4              |
| 21         | 1               | 10              | 5                            | 5                 | 1110           | 100            | 76.2              |
| 21         | 1               | 12              | 4                            | 4                 | 1111           | 011            | 81.0              |
| 20         | 1               | 3               | 8                            | 8                 | 1010           | 111            | 60.0              |
| 20         | 1               | 5               | 7                            | 7                 | 1011           | 110            | 65.0              |
| 20         | 1               | 7               | 6                            | 6                 | 1100           | 101            | 70.0              |
| 20         | 1               | 9               | 5                            | 5                 | 1101           | 100            | 75.0              |
| 20         | 1               | 11              | 4                            | 4                 | 1110           | 011            | 80.0              |
| 20         | 1               | 13              | 3                            | 3                 | 1111           | 010            | 85.0              |
| 19         | 1               | 2               | 8                            | 8                 | 1001           | 111            | 57.9              |
| 19         | 1               | 4               | 7                            | 7                 | 1010           | 110            | 63.2              |
| 19         | 1               | 6               | 6                            | 6                 | 1011           | 101            | 68.4              |
| 19         | 1               | 8               | 5                            | 5                 | 1100           | 100            | 73.7              |
| 19         | 1               | 10              | 4                            | 4                 | 1101           | 011            | 78.9              |
| 19         | 1               | 12              | 3                            | 3                 | 1110           | 010            | 84.2              |
| 19         | 1               | 14              | 2                            | 2                 | 1111           | 001            | 89.5              |
| 18         | 1               | 1               | 8                            | 8                 | 1000           | 111            | 55.6              |
| 18         | 1               | 3               | 7                            | 7                 | 1001           | 110            | 61.1              |
| 18         | 1               | 5               | 6                            | 6                 | 1010           | 101            | 66.7              |
| 18         | 1               | 7               | 5                            | 5                 | 1011           | 100            | 72.2              |
| 18         | 1               | 9               | 4                            | 4                 | 1100           | 011            | 77.8              |
| 18         | 1               | 11              | 3                            | 3                 | 1101           | 010            | 83.3              |
| 18         | 1               | 13              | 2                            | 2                 | 1110           | 001            | 88.9              |
| 18         | 1               | 15              | 1                            | 1                 | 1111           | 000            | 94.4              |
| 17         | 1               | 2               | 7                            | 7                 | 1000           | 110            | 58.8              |

### Table 14-27 Settable bit rate combinations (1/3)



|            | Val             | lid bit rate set |                   | CnBTR regi<br>va  |                | Sampling<br>point |          |
|------------|-----------------|------------------|-------------------|-------------------|----------------|-------------------|----------|
| DBT length | SYNC<br>SEGMENT | PROP<br>SEGMENT  | PHASE<br>SEGMENT1 | PHASE<br>SEGMENT2 | TSEG1<br>[3:0] | TSEG2<br>[2:0]    | (unit %) |
| 17         | 1               | 4                | 6                 | 6                 | 1001           | 101               | 64.7     |
| 17         | 1               | 6                | 5                 | 5                 | 1010           | 100               | 70.6     |
| 17         | 1               | 8                | 4                 | 4                 | 1011           | 011               | 76.5     |
| 17         | 1               | 10               | 3                 | 3                 | 1100           | 010               | 82.4     |
| 17         | 1               | 12               | 2                 | 2                 | 1101           | 001               | 88.2     |
| 17         | 1               | 14               | 1                 | 1                 | 1110           | 000               | 94.1     |
| 16         | 1               | 1                | 7                 | 7                 | 0111           | 110               | 56.3     |
| 16         | 1               | 3                | 6                 | 6                 | 1000           | 101               | 62.5     |
| 16         | 1               | 5                | 5                 | 5                 | 1001           | 100               | 68.8     |
| 16         | 1               | 7                | 4                 | 4                 | 1010           | 011               | 75.0     |
| 16         | 1               | 9                | 3                 | 3                 | 1011           | 010               | 81.3     |
| 16         | 1               | 11               | 2                 | 2                 | 1100           | 001               | 87.5     |
| 16         | 1               | 13               | 1                 | 1                 | 1101           | 000               | 93.8     |
| 15         | 1               | 2                | 6                 | 6                 | 0111           | 101               | 60.0     |
| 15         | 1               | 4                | 5                 | 5                 | 1000           | 100               | 66.7     |
| 15         | 1               | 6                | 4                 | 4                 | 1001           | 011               | 73.3     |
| 15         | 1               | 8                | 3                 | 3                 | 1010           | 010               | 80.0     |
| 15         | 1               | 10               | 2                 | 2                 | 1011           | 001               | 86.7     |
| 15         | 1               | 12               | 1                 | 1                 | 1100           | 000               | 93.3     |
| 14         | 1               | 1                | 6                 | 6                 | 0110           | 101               | 57.1     |
| 14         | 1               | 3                | 5                 | 5                 | 0111           | 100               | 64.3     |
| 14         | 1               | 5                | 4                 | 4                 | 1000           | 011               | 71.4     |
| 14         | 1               | 7                | 3                 | 3                 | 1001           | 010               | 78.6     |
| 14         | 1               | 9                | 2                 | 2                 | 1010           | 001               | 85.7     |
| 14         | 1               | 11               | 1                 | 1                 | 1011           | 000               | 92.9     |
| 13         | 1               | 2                | 5                 | 5                 | 0110           | 100               | 61.5     |
| 13         | 1               | 4                | 4                 | 4                 | 0111           | 011               | 69.2     |
| 13         | 1               | 6                | 3                 | 3                 | 1000           | 010               | 76.9     |
| 13         | 1               | 8                | 2                 | 2                 | 1001           | 001               | 84.6     |
| 13         | 1               | 10               | 1                 | 1                 | 1010           | 000               | 92.3     |
| 12         | 1               | 1                | 5                 | 5                 | 0101           | 100               | 58.3     |
| 12         | 1               | 3                | 4                 | 4                 | 0110           | 011               | 66.7     |
| 12         | 1               | 5                | 3                 | 3                 | 0111           | 010               | 75.0     |

### Table 14-27 Settable bit rate combinations (2/3)



|                | Val             | CnBTR regi<br>va | Sampling<br>point          |   |                |                |          |
|----------------|-----------------|------------------|----------------------------|---|----------------|----------------|----------|
| DBT length     | SYNC<br>SEGMENT | PROP<br>SEGMENT  | PHASE PHA<br>SEGMENT1 SEGM |   | TSEG1<br>[3:0] | TSEG2<br>[2:0] | (unit %) |
| 12             | 1               | 7                | 2                          | 2 | 1000           | 001            | 83.3     |
| 12             | 1               | 9                | 1                          | 1 | 1001           | 000            | 91.7     |
| 11             | 1               | 2                | 4                          | 4 | 0101           | 011            | 63.6     |
| 11             | 1               | 4                | 3                          | 3 | 0110           | 010            | 72.7     |
| 11             | 1               | 6                | 2                          | 2 | 0111           | 001            | 81.8     |
| 11             | 1               | 8                | 1                          | 1 | 1000           | 000            | 90.9     |
| 10             | 1               | 1                | 4                          | 4 | 0100           | 011            | 60.0     |
| 10             | 1               | 3                | 3                          | 3 | 0101           | 010            | 70.0     |
| 10             | 1               | 5                | 2                          | 2 | 0110           | 001            | 80.0     |
| 10             | 1               | 7                | 1                          | 1 | 0111           | 000            | 90.0     |
| 9              | 1               | 2                | 3                          | 3 | 0100           | 010            | 66.7     |
| 9              | 1               | 4                | 2                          | 2 | 0101           | 001            | 77.8     |
| 9              | 1               | 6                | 1                          | 1 | 0110           | 000            | 88.9     |
| 8              | 1               | 1                | 3                          | 3 | 0011           | 010            | 62.5     |
| 8              | 1               | 3                | 2                          | 2 | 0100           | 001            | 75.0     |
| 8              | 1               | 5                | 1                          | 1 | 0101           | 000            | 87.5     |
| 7 <sup>a</sup> | 1               | 2                | 2                          | 2 | 0011           | 001            | 71.4     |
| 7 <sup>a</sup> | 1               | 4                | 1                          | 1 | 0100           | 000            | 85.7     |
| 6 <sup>a</sup> | 1               | 1                | 2                          | 2 | 0010           | 001            | 66.7     |
| 6 <sup>a</sup> | 1               | 3                | 1                          | 1 | 0011           | 000            | 83.3     |
| 5 <sup>a</sup> | 1               | 2                | 1                          | 1 | 0010           | 000            | 80.0     |
| 4 <sup>a</sup> | 1               | 1                | 1                          | 1 | 0001           | 000            | 75.0     |

| Table 14-27 | Settable bit rate combinations | (3/3) |
|-------------|--------------------------------|-------|
|-------------|--------------------------------|-------|

<sup>a)</sup> Setting with a DBT value of 7 or less is valid only when the value of the CnBRP register is other than 00<sub>H</sub>.

Caution

The values in *Table 14-27* do not guarantee the operation of the network system. Thoroughly check the effect on the network system, taking into consideration oscillation errors and delays of the CAN bus and CAN transceiver.



### 14.15.2 Representative examples of baud rate settings

*Table 14-28* and *Table 14-29* show representative examples of baud rate settings.

## Table 14-28Representative examples of baud rate settings<br/>(f<sub>CANMOD</sub> = 8 MHz) (1/2)

| Set baud                   | Division                      | CnBRP                 |                  | Valid bit rate setting (unit: kbps) CnBTR register setting value Sam |                 |                       |                       |                |                |                    |  |
|----------------------------|-------------------------------|-----------------------|------------------|----------------------------------------------------------------------|-----------------|-----------------------|-----------------------|----------------|----------------|--------------------|--|
| rate value<br>(unit: kbps) | ratio of<br>CnBRP<br>register | register set<br>value | Length<br>of DBT | SYNC<br>SEGMENT                                                      | PROP<br>SEGMENT | PHASE<br>SEGMENT<br>1 | PHASE<br>SEGMENT<br>2 | TSEG1<br>[3:0] | TSEG2<br>[2:0] | point<br>(unit: %) |  |
| 1000                       | 1                             | 00000000              | 8                | 1                                                                    | 1               | 3                     | 3                     | 0011           | 010            | 62.5               |  |
| 1000                       | 1                             | 00000000              | 8                | 1                                                                    | 3               | 2                     | 2                     | 0100           | 001            | 75.0               |  |
| 1000                       | 1                             | 00000000              | 8                | 1                                                                    | 5               | 1                     | 1                     | 0101           | 000            | 87.5               |  |
| 500                        | 1                             | 00000000              | 16               | 1                                                                    | 1               | 7                     | 7                     | 0111           | 110            | 56.3               |  |
| 500                        | 1                             | 00000000              | 16               | 1                                                                    | 3               | 6                     | 6                     | 1000           | 101            | 62.5               |  |
| 500                        | 1                             | 00000000              | 16               | 1                                                                    | 5               | 5                     | 5                     | 1001           | 100            | 68.8               |  |
| 500                        | 1                             | 00000000              | 16               | 1                                                                    | 7               | 4                     | 4                     | 1010           | 011            | 75.0               |  |
| 500                        | 1                             | 00000000              | 16               | 1                                                                    | 9               | 3                     | 3                     | 1011           | 010            | 81.3               |  |
| 500                        | 1                             | 00000000              | 16               | 1                                                                    | 11              | 2                     | 2                     | 1100           | 001            | 87.5               |  |
| 500                        | 1                             | 00000000              | 16               | 1                                                                    | 13              | 1                     | 1                     | 1101           | 000            | 93.8               |  |
| 500                        | 2                             | 00000001              | 8                | 1                                                                    | 1               | 3                     | 3                     | 0011           | 010            | 62.5               |  |
| 500                        | 2                             | 00000001              | 8                | 1                                                                    | 3               | 2                     | 2                     | 0100           | 001            | 75.0               |  |
| 500                        | 2                             | 00000001              | 8                | 1                                                                    | 5               | 1                     | 1                     | 0101           | 000            | 87.5               |  |
| 250                        | 2                             | 00000001              | 16               | 1                                                                    | 1               | 7                     | 7                     | 0111           | 110            | 56.3               |  |
| 250                        | 2                             | 00000001              | 16               | 1                                                                    | 3               | 6                     | 6                     | 1000           | 101            | 62.5               |  |
| 250                        | 2                             | 00000001              | 16               | 1                                                                    | 5               | 5                     | 5                     | 1001           | 100            | 68.8               |  |
| 250                        | 2                             | 00000001              | 16               | 1                                                                    | 7               | 4                     | 4                     | 1010           | 011            | 75.0               |  |
| 250                        | 2                             | 00000001              | 16               | 1                                                                    | 9               | 3                     | 3                     | 1011           | 010            | 81.3               |  |
| 250                        | 2                             | 00000001              | 16               | 1                                                                    | 11              | 2                     | 2                     | 1100           | 001            | 87.5               |  |
| 250                        | 2                             | 00000001              | 16               | 1                                                                    | 13              | 1                     | 1                     | 1101           | 000            | 93.8               |  |
| 250                        | 4                             | 00000011              | 8                | 1                                                                    | 3               | 2                     | 2                     | 0100           | 001            | 75.0               |  |
| 250                        | 4                             | 00000011              | 8                | 1                                                                    | 5               | 1                     | 1                     | 0101           | 000            | 87.5               |  |
| 125                        | 4                             | 00000011              | 16               | 1                                                                    | 1               | 7                     | 7                     | 0111           | 110            | 56.3               |  |
| 125                        | 4                             | 00000011              | 16               | 1                                                                    | 3               | 6                     | 6                     | 1000           | 101            | 62.5               |  |
| 125                        | 4                             | 00000011              | 16               | 1                                                                    | 5               | 5                     | 5                     | 1001           | 100            | 68.8               |  |
| 125                        | 4                             | 00000011              | 16               | 1                                                                    | 7               | 4                     | 4                     | 1010           | 011            | 75.0               |  |
| 125                        | 4                             | 00000011              | 16               | 1                                                                    | 9               | 3                     | 3                     | 1011           | 010            | 81.3               |  |
| 125                        | 4                             | 00000011              | 16               | 1                                                                    | 11              | 2                     | 2                     | 1100           | 001            | 87.5               |  |
| 125                        | 4                             | 00000011              | 16               | 1                                                                    | 13              | 1                     | 1                     | 1101           | 000            | 93.8               |  |
| 125                        | 8                             | 00000111              | 8                | 1                                                                    | 3               | 2                     | 2                     | 0100           | 001            | 75.0               |  |
| 125                        | 8                             | 00000111              | 8                | 1                                                                    | 5               | 1                     | 1                     | 0101           | 000            | 87.5               |  |
| 100                        | 4                             | 00000011              | 20               | 1                                                                    | 7               | 6                     | 6                     | 1100           | 101            | 70.0               |  |
| 100                        | 4                             | 00000011              | 20               | 1                                                                    | 9               | 5                     | 5                     | 1101           | 100            | 75.0               |  |
| 100                        | 5                             | 00000100              | 16               | 1                                                                    | 7               | 4                     | 4                     | 1010           | 011            | 75.0               |  |



| Table 14-28 | Representative examples of baud rate settings |
|-------------|-----------------------------------------------|
|             | (f <sub>CANMOD</sub> = 8 MHz) (2/2)           |

| Set baud                   | Division<br>ratio of | CnBRP                 |                  | Valid bit rate setting (unit: kbps) CnBTR register setting value Sampl |                 |                       |                       |                |                |                    |
|----------------------------|----------------------|-----------------------|------------------|------------------------------------------------------------------------|-----------------|-----------------------|-----------------------|----------------|----------------|--------------------|
| rate value<br>(unit: kbps) | CnBRP<br>register    | register set<br>value | Length<br>of DBT | SYNC<br>SEGMENT                                                        | PROP<br>SEGMENT | PHASE<br>SEGMENT<br>1 | PHASE<br>SEGMENT<br>2 | TSEG1<br>[3:0] | TSEG2<br>[2:0] | point<br>(unit: %) |
| 100                        | 5                    | 00000100              | 16               | 1                                                                      | 9               | 3                     | 3                     | 1011           | 010            | 81.3               |
| 100                        | 8                    | 00000111              | 10               | 1                                                                      | 3               | 3                     | 3                     | 0101           | 010            | 70.0               |
| 100                        | 8                    | 00000111              | 10               | 1                                                                      | 5               | 2                     | 2                     | 0110           | 001            | 80.0               |
| 100                        | 10                   | 00001001              | 8                | 1                                                                      | 3               | 2                     | 2                     | 0100           | 001            | 75.0               |
| 100                        | 10                   | 00001001              | 8                | 1                                                                      | 5               | 1                     | 1                     | 0101           | 000            | 87.5               |
| 83.3                       | 4                    | 00000011              | 24               | 1                                                                      | 7               | 8                     | 8                     | 1110           | 111            | 66.7               |
| 83.3                       | 4                    | 00000011              | 24               | 1                                                                      | 9               | 7                     | 7                     | 1111           | 110            | 70.8               |
| 83.3                       | 6                    | 00000101              | 16               | 1                                                                      | 5               | 5                     | 5                     | 1001           | 100            | 68.8               |
| 83.3                       | 6                    | 00000101              | 16               | 1                                                                      | 7               | 4                     | 4                     | 1010           | 011            | 75.0               |
| 83.3                       | 6                    | 00000101              | 16               | 1                                                                      | 9               | 3                     | 3                     | 1011           | 010            | 81.3               |
| 83.3                       | 6                    | 00000101              | 16               | 1                                                                      | 11              | 2                     | 2                     | 1100           | 001            | 87.5               |
| 83.3                       | 8                    | 00000111              | 12               | 1                                                                      | 5               | 3                     | 3                     | 0111           | 010            | 75.0               |
| 83.3                       | 8                    | 00000111              | 12               | 1                                                                      | 7               | 2                     | 2                     | 1000           | 001            | 83.3               |
| 83.3                       | 12                   | 00001011              | 8                | 1                                                                      | 3               | 2                     | 2                     | 0100           | 001            | 75.0               |
| 83.3                       | 12                   | 00001011              | 8                | 1                                                                      | 5               | 1                     | 1                     | 0101           | 000            | 87.5               |
| 33.3                       | 10                   | 00001001              | 24               | 1                                                                      | 7               | 8                     | 8                     | 1110           | 111            | 66.7               |
| 33.3                       | 10                   | 00001001              | 24               | 1                                                                      | 9               | 7                     | 7                     | 1111           | 110            | 70.8               |
| 33.3                       | 12                   | 00001011              | 20               | 1                                                                      | 7               | 6                     | 6                     | 1100           | 101            | 70.0               |
| 33.3                       | 12                   | 00001011              | 20               | 1                                                                      | 9               | 5                     | 5                     | 1101           | 100            | 75.0               |
| 33.3                       | 15                   | 00001110              | 16               | 1                                                                      | 7               | 4                     | 4                     | 1010           | 011            | 75.0               |
| 33.3                       | 15                   | 00001110              | 16               | 1                                                                      | 9               | 3                     | 3                     | 1011           | 010            | 81.3               |
| 33.3                       | 16                   | 00001111              | 15               | 1                                                                      | 6               | 4                     | 4                     | 1001           | 011            | 73.3               |
| 33.3                       | 16                   | 00001111              | 15               | 1                                                                      | 8               | 3                     | 3                     | 1010           | 010            | 80.0               |
| 33.3                       | 20                   | 00010011              | 12               | 1                                                                      | 5               | 3                     | 3                     | 0111           | 010            | 75.0               |
| 33.3                       | 20                   | 00010011              | 12               | 1                                                                      | 7               | 2                     | 2                     | 1000           | 001            | 83.3               |
| 33.3                       | 24                   | 00010111              | 10               | 1                                                                      | 3               | 3                     | 3                     | 0101           | 010            | 70.0               |
| 33.3                       | 24                   | 00010111              | 10               | 1                                                                      | 5               | 2                     | 2                     | 0110           | 001            | 80.0               |
| 33.3                       | 30                   | 00011101              | 8                | 1                                                                      | 3               | 2                     | 2                     | 0100           | 001            | 75.0               |
| 33.3                       | 30                   | 00011101              | 8                | 1                                                                      | 5               | 1                     | 1                     | 0101           | 000            | 87.5               |

#### Caution

The values in *Table 14-28* do not guarantee the operation of the network system. Thoroughly check the effect on the network system, taking into consideration oscillation errors and delays of the CAN bus and CAN transceiver.



# Table 14-29Representative examples of baud rate settings<br/> $(f_{CANMOD} = 16 \text{ MHz}) (1/2)$

| Set baud                   | Division<br>ratio of         | CnBRP                 |                  | Valid b         | it rate setting | (unit: kbps)          |                       | -              | ister setting<br>lue | Sampling           |
|----------------------------|------------------------------|-----------------------|------------------|-----------------|-----------------|-----------------------|-----------------------|----------------|----------------------|--------------------|
| rate value<br>(unit: kbps) | ate value CnBBP register set | register set<br>value | Length<br>of DBT | SYNC<br>SEGMENT | PROP<br>SEGMENT | PHASE<br>SEGMENT<br>1 | PHASE<br>SEGMENT<br>2 | TSEG1<br>[3:0] | TSEG2<br>[2:0]       | point<br>(unit: %) |
| 1000                       | 1                            | 00000000              | 16               | 1               | 1               | 7                     | 7                     | 0111           | 110                  | 56.3               |
| 1000                       | 1                            | 00000000              | 16               | 1               | 3               | 6                     | 6                     | 1000           | 101                  | 62.5               |
| 1000                       | 1                            | 00000000              | 16               | 1               | 5               | 5                     | 5                     | 1001           | 100                  | 68.8               |
| 1000                       | 1                            | 00000000              | 16               | 1               | 7               | 4                     | 4                     | 1010           | 011                  | 75.0               |
| 1000                       | 1                            | 00000000              | 16               | 1               | 9               | 3                     | 3                     | 1011           | 010                  | 81.3               |
| 1000                       | 1                            | 00000000              | 16               | 1               | 11              | 2                     | 2                     | 1100           | 001                  | 87.5               |
| 1000                       | 1                            | 00000000              | 16               | 1               | 13              | 1                     | 1                     | 1101           | 000                  | 93.8               |
| 1000                       | 2                            | 00000001              | 8                | 1               | 3               | 2                     | 2                     | 0100           | 001                  | 75.0               |
| 1000                       | 2                            | 00000001              | 8                | 1               | 5               | 1                     | 1                     | 0101           | 000                  | 87.5               |
| 500                        | 2                            | 00000001              | 16               | 1               | 1               | 7                     | 7                     | 0111           | 110                  | 56.3               |
| 500                        | 2                            | 00000001              | 16               | 1               | 3               | 6                     | 6                     | 1000           | 101                  | 62.5               |
| 500                        | 2                            | 00000001              | 16               | 1               | 5               | 5                     | 5                     | 1001           | 100                  | 68.8               |
| 500                        | 2                            | 00000001              | 16               | 1               | 7               | 4                     | 4                     | 1010           | 011                  | 75.0               |
| 500                        | 2                            | 00000001              | 16               | 1               | 9               | 3                     | 3                     | 1011           | 010                  | 81.3               |
| 500                        | 2                            | 00000001              | 16               | 1               | 11              | 2                     | 2                     | 1100           | 001                  | 87.5               |
| 500                        | 2                            | 00000001              | 16               | 1               | 13              | 1                     | 1                     | 1101           | 000                  | 93.8               |
| 500                        | 4                            | 00000011              | 8                | 1               | 3               | 2                     | 2                     | 0100           | 001                  | 75.0               |
| 500                        | 4                            | 00000011              | 8                | 1               | 5               | 1                     | 1                     | 0101           | 000                  | 87.5               |
| 250                        | 4                            | 00000011              | 16               | 1               | 3               | 6                     | 6                     | 1000           | 101                  | 62.5               |
| 250                        | 4                            | 00000011              | 16               | 1               | 5               | 5                     | 5                     | 1001           | 100                  | 68.8               |
| 250                        | 4                            | 00000011              | 16               | 1               | 7               | 4                     | 4                     | 1010           | 011                  | 75.0               |
| 250                        | 4                            | 00000011              | 16               | 1               | 9               | 3                     | 3                     | 1011           | 010                  | 81.3               |
| 250                        | 4                            | 00000011              | 16               | 1               | 11              | 2                     | 2                     | 1100           | 001                  | 87.5               |
| 250                        | 8                            | 00000111              | 8                | 1               | 3               | 2                     | 2                     | 0100           | 001                  | 75.0               |
| 250                        | 8                            | 00000111              | 8                | 1               | 5               | 1                     | 1                     | 0101           | 000                  | 87.5               |
| 125                        | 8                            | 00000111              | 16               | 1               | 3               | 6                     | 6                     | 1000           | 101                  | 62.5               |
| 125                        | 8                            | 00000111              | 16               | 1               | 7               | 4                     | 4                     | 1010           | 011                  | 75.0               |
| 125                        | 8                            | 00000111              | 16               | 1               | 9               | 3                     | 3                     | 1011           | 010                  | 81.3               |
| 125                        | 8                            | 00000111              | 16               | 1               | 11              | 2                     | 2                     | 1100           | 001                  | 87.5               |
| 125                        | 16                           | 00001111              | 8                | 1               | 3               | 2                     | 2                     | 0100           | 001                  | 75.0               |
| 125                        | 16                           | 00001111              | 8                | 1               | 5               | 1                     | 1                     | 0101           | 000                  | 87.5               |
| 100                        | 8                            | 00000111              | 20               | 1               | 9               | 5                     | 5                     | 1101           | 100                  | 75.0               |
| 100                        | 8                            | 00000111              | 20               | 1               | 11              | 4                     | 4                     | 1110           | 011                  | 80.0               |
| 100                        | 10                           | 00001001              | 16               | 1               | 7               | 4                     | 4                     | 1010           | 011                  | 75.0               |
| 100                        | 10                           | 00001001              | 16               | 1               | 9               | 3                     | 3                     | 1011           | 010                  | 81.3               |
| 100                        | 16                           | 00001111              | 10               | 1               | 3               | 3                     | 3                     | 0101           | 010                  | 70.0               |
| 100                        | 16                           | 00001111              | 10               | 1               | 5               | 2                     | 2                     | 0110           | 001                  | 80.0               |
| 100                        | 20                           | 00010011              | 8                | 1               | 3               | 2                     | 2                     | 0100           | 001                  | 75.0               |



| Set baud                   | Division<br>ratio of | CnBRP                 | Valid bit rate setting (unit: kbps) CnBTR register setting value |                 |                 |                       |                       |                | •              | Sampling           |
|----------------------------|----------------------|-----------------------|------------------------------------------------------------------|-----------------|-----------------|-----------------------|-----------------------|----------------|----------------|--------------------|
| rate value<br>(unit: kbps) | CnBRP<br>register    | register set<br>value | Length<br>of DBT                                                 | SYNC<br>SEGMENT | PROP<br>SEGMENT | PHASE<br>SEGMENT<br>1 | PHASE<br>SEGMENT<br>2 | TSEG1<br>[3:0] | TSEG2<br>[2:0] | point<br>(unit: %) |
| 83.3                       | 8                    | 00000111              | 24                                                               | 1               | 7               | 8                     | 8                     | 1110           | 111            | 66.7               |
| 83.3                       | 8                    | 00000111              | 24                                                               | 1               | 9               | 7                     | 7                     | 1111           | 110            | 70.8               |
| 83.3                       | 12                   | 00001011              | 16                                                               | 1               | 7               | 4                     | 4                     | 1010           | 011            | 75.0               |
| 83.3                       | 12                   | 00001011              | 16                                                               | 1               | 9               | 3                     | 3                     | 1011           | 010            | 81.3               |
| 83.3                       | 12                   | 00001011              | 16                                                               | 1               | 11              | 2                     | 2                     | 1100           | 001            | 87.5               |
| 83.3                       | 16                   | 00001111              | 12                                                               | 1               | 5               | 3                     | 3                     | 0111           | 010            | 75.0               |
| 83.3                       | 16                   | 00001111              | 12                                                               | 1               | 7               | 2                     | 2                     | 1000           | 001            | 83.3               |
| 83.3                       | 24                   | 00010111              | 8                                                                | 1               | 3               | 2                     | 2                     | 0100           | 001            | 75.0               |
| 83.3                       | 24                   | 00010111              | 8                                                                | 1               | 5               | 1                     | 1                     | 0101           | 000            | 87.5               |
| 33.3                       | 30                   | 00011101              | 24                                                               | 1               | 7               | 8                     | 8                     | 1110           | 111            | 66.7               |
| 33.3                       | 30                   | 00011101              | 24                                                               | 1               | 9               | 7                     | 7                     | 1111           | 110            | 70.8               |
| 33.3                       | 24                   | 00010111              | 20                                                               | 1               | 9               | 5                     | 5                     | 1101           | 100            | 75.0               |
| 33.3                       | 24                   | 00010111              | 20                                                               | 1               | 11              | 4                     | 4                     | 1110           | 011            | 80.0               |
| 33.3                       | 30                   | 00011101              | 16                                                               | 1               | 7               | 4                     | 4                     | 1010           | 011            | 75.0               |
| 33.3                       | 30                   | 00011101              | 16                                                               | 1               | 9               | 3                     | 3                     | 1011           | 010            | 81.3               |
| 33.3                       | 32                   | 00011111              | 15                                                               | 1               | 8               | 3                     | 3                     | 1010           | 010            | 80.0               |
| 33.3                       | 32                   | 00011111              | 15                                                               | 1               | 10              | 2                     | 2                     | 1011           | 001            | 86.7               |
| 33.3                       | 37                   | 00100100              | 13                                                               | 1               | 6               | 3                     | 3                     | 1000           | 010            | 76.9               |
| 33.3                       | 37                   | 00100100              | 13                                                               | 1               | 8               | 2                     | 2                     | 1001           | 001            | 84.6               |
| 33.3                       | 40                   | 00100111              | 12                                                               | 1               | 5               | 3                     | 3                     | 0111           | 010            | 75.0               |
| 33.3                       | 40                   | 00100111              | 12                                                               | 1               | 7               | 2                     | 2                     | 1000           | 001            | 83.3               |
| 33.3                       | 48                   | 00101111              | 10                                                               | 1               | 3               | 3                     | 3                     | 0101           | 010            | 70.0               |
| 33.3                       | 48                   | 00101111              | 10                                                               | 1               | 5               | 2                     | 2                     | 0110           | 001            | 80.0               |
| 33.3                       | 60                   | 00111011              | 8                                                                | 1               | 3               | 2                     | 2                     | 0100           | 001            | 75.0               |
| 33.3                       | 60                   | 00111011              | 8                                                                | 1               | 5               | 1                     | 1                     | 0101           | 000            | 87.5               |

# Table 14-29Representative examples of baud rate settings<br/> $(f_{CANMOD} = 16 \text{ MHz})$ (2/2)

Caution

The values in *Table 14-29* do not guarantee the operation of the network system. Thoroughly check the effect on the network system, taking into consideration oscillation errors and delays of the CAN bus and CAN transceiver.



### 14.16 Operation of CAN Controller

The processing procedure for showing in this chapter is recommended processing procedure to operate CAN controller.

Develop the program referring to recommended processing procedure in this chapter.











Caution Af

After setting the CAN module to the initialization mode, avoid setting the module to another operation mode immediately after. If it is necessary to immediately set the module to another operation mode, be sure to access registers other than the CnCTRL and CnGMCTRL registers (e.g., set a message buffer).





Message buffer initialization Figure 14-37

Caution 1. Before a message buffer is initialized, the RDY bit must be cleared.

2. Make the following settings for message buffers not used by the application.

- Clear the RDY, TRQ, and DN bits of the CnMCTRLm register to 0.
- Clear the MA0 bit of the CnMCONFm register to 0.







Figure 14-38 Message buffer redefinition



## *Figure 14-39* shows the processing for a transmit message buffer during transmission (MT[2:0] bits of CnMCONFm register = $000_B$ ).



Figure 14-39 Message buffer redefinition during transmission







Figure 14-40 Message transmit processing

Caution

1. The TRQ bit should be set after the RDY bit is set.

2. The RDY bit and TRQ bit should not be set at the same time.







Figure 14-41 ABT message transmit processing

**Note** This processing (normal operation mode with ABT) can only be applied to message buffers 0 to 7. For message buffers other than the ABT message buffers, see *Figure 14-40 on page 482*.

Caution The ABTTRG bit should be set to 1 after the TSTAT bit is cleared to 0. Checking the TSTAT bit and setting the ABTTRG bit to 1 must be processed consecutively.



#### Figure 14-42 Transmission via interrupt (using CnLOPT register)

Caution 1. The TRQ bit should be set after the RDY bit is set.

2. The RDY bit and TRQ bit should not be set at the same time.

Note Also check the MBON flag at the beginning and at the end of the interrupt routine, in order to check the access to the message buffers as well as TX history list registers, in case a pending sleep mode had been executed. If MBON is detected to be cleared at any check, the actions and results of the processing have to be discarded and processed again, after MBON is set again.

It is recommended to cancel any sleep mode requests, before processing TX interrupts.





Figure 14-43 Transmission via interrupt (using CnTGPT register)

Caution 1. The TRQ bit should be set after the RDY bit is set.

2. The RDY bit and TRQ bit should not be set at the same time.



- Note 1. Also check the MBON flag at the beginning and at the end of the interrupt routine, in order to check the access to the message buffers as well as TX history list registers, in case a pending sleep mode had been executed. If MBON is detected to be cleared at any check, the actions and results of the processing have to be discarded and processed again, after MBON is set again. It is recommended to cancel any sleep mode requests, before processing TX interrupts.
  - 2. If TOVF was set once, the transmit history list is inconsistent. Consider to scan all configured transmit buffers for completed transmissions.





Figure 14-44 Transmission via software polling

Caution 1. The TRQ bit should be set after the RDY bit is set.

2. The RDY bit and TRQ bit should not be set at the same time.



- Note 1. Also check the MBON flag at the beginning and at the end of the polling routine, in order to check the access to the message buffers as well as TX history list registers, in case a pending sleep mode had been executed. If MBON is detected to be cleared at any check, the actions and results of the processing have to be discarded and processed again, after MBON is set again.
  - 2. If TOVF was set once, the transmit history list is inconsistent. Consider to scan all configured transmit buffers for completed transmissions.





- Figure 14-45 Transmission abort processing (except normal operation mode with ABT)
  - **Note** There is a possibility of starting the transmission without being aborted even if TRQ bit is cleared, because the transmission request to protocol layer might already been accepted between 11 bits, total of interframe space (3 bits) and suspend transmission (8 bits).

Caution 1.

n 1. Clear the TRQ bit for aborting transmission request, not the RDY bit.

- **2.** Before making a sleep mode transition request, confirm that there is no transmission request left using this processing.
- **3.** The TSTAT bit can be periodically checked by a user application or can be checked after the transmit completion interrupt.
- Do not execute any new transmission request including in the other message buffers while transmission abort processing is in progress.
- 5. If a new transmission request is executed for a message buffer within 500 clocks of the AFCAN macro, after transmission abort process and before IFS (Inter-Frame Space), that message might be transmitted in the next following transmission, although its ID priority was low.





Figure 14-46 Transmission abort processing except for ABT transmission (normal operation mode with ABT)

Caution 1. Clear the TRQ bit for aborting transmission request, not the RDY bit.

- **2.** Before making a sleep mode transition request, confirm that there is no transmission request left using this processing.
- **3.** The TSTAT bit can be periodically checked by a user application or can be checked after the transmit completion interrupt.
- 4. Do not execute any new transmission request including in the other message buffers while transmission abort processing is in progress.



*Figure 14-47* shows the processing to skip resumption of transmitting a message that was stopped when transmission of an ABT message buffer was aborted.



Figure 14-47 Transmission abort processing (normal operation mode with ABT)

**Caution 1.** Do not set any transmission requests while ABT transmission abort processing is in progress.

2. Make a CAN sleep mode/CAN stop mode transition request after the ABTTRG bit is cleared (after ABT mode is aborted) following the procedure shown in *Figure 14-47* or *Figure 14-48*. When clearing a transmission request in an area other than the ABT area, follow the procedure shown in *Figure 14-45 on page 489*.



*Figure 14-48* shows the processing to not skip resumption of transmitting a message that was stopped when transmission of an ABT message buffer was aborted.



- Figure 14-48 ABT transmission request abort processing (normal operation mode with ABT)
  - **Caution 1.** Do not set any transmission requests while ABT transmission abort processing is in progress.
    - 2. Make a CAN sleep mode/CAN stop mode request after the ABTTRG bit is cleared (after ABT mode is stopped) following the procedure shown in *Figure 14-47* or *Figure 14-48*. When clearing a transmission request in an area other than the ABT area, follow the procedure shown in *Figure 14-45* on page 489.





- Figure 14-49 Reception via interrupt (using CnLIPT register)
  - **Note** Also check the MBON flag at the beginning and at the end of the interrupt routine, in order to check the access to the message buffers as well as reception history list registers, in case a pending sleep mode had been executed. If MBON is detected to be cleared at any check, the actions and results of the processing have to be discarded and processed again, after MBON is set again.

It is recommended to cancel any sleep mode requests, before processing RX interrupts.





Figure 14-50 Reception via interrupt (using CnRGPT register)

- Note 1. Check the MUC and DN bits using one read access.
  - **2.** Depending of the processing target of the application, two ways are possible:

– Way A: The message is not processed within this pass, but with the next pass, depending on the timing this can happen latest with the next Receive Interrupt.

Other messages will be processed earlier.

- Way B: The message is processed within this pass, the loop waits on this message.

Other messages will be processed later.



3. Also check the MBON flag at the beginning and at the end of the interrupt routine, in order to check the access to the message buffers as well as reception history list registers, in case a pending sleep mode had been executed. If MBON is detected to be cleared at any check, the actions and results of the processing have to be discarded and processed again, after MBON is set again.

It is recommended to cancel any sleep mode requests, before processing RX interrupts.

4. If ROVF was set once, the receive history list is inconsistent. Consider to scan all configured receive buffers for receptions.





- Figure 14-51 Reception via interrupt (using CnRGPT register), alternative way
  - Note 1. Also check the MBON flag at the beginning and at the end of the interrupt routine, in order to check the access to the message buffers as well as reception history list registers, in case a pending sleep mode had been executed. If MBON is detected to be cleared at any check, the actions and results of the processing have to be discarded and processed again, after MBON is set again. It is recommended to cancel any sleep mode requests, before processing

RX interrupts.

- 2. If ROVF was set once, the receive history list is inconsistent. Consider to scan all configured receive buffers for receptions.
- **3.** This flow will not provide most recently received data for the application. However, due to less effort on processing, it reduces interrupt load.
- 4. The overwrite function (CnMCONFm.OWS=1) must not be used with this flow data inconsistency could occur.
- 5. It can be used alternatively to Figure 14-50 on page 494.



Figure 14-52 Reception via software polling

- **Note** 1. Also check the MBON flag at the beginning and at the end of the polling routine, in order to check the access to the message buffers as well as reception history list registers, in case a pending sleep mode had been executed. If MBON is detected to be cleared at any check, the actions and results of the processing have to be discarded and processed again, after MBON is set again.
  - 2. If ROVF was set once, the receive history list is inconsistent. Consider to scan all configured receive buffers for receptions.







(set OPMODE)

Clear CINTS5 bit

**Caution** To abort transmission before making a request for the CAN sleep mode, perform processing according to *Figure 14-45 on page 489* and *Figure 14-47 on page 491*.



Figure 14-54 Clear CAN sleep/stop mode





Figure 14-55 Bus-off recovery (except normal operation mode with ABT)

Caution When the transmission from the initialization mode to any operation modes is requested to execute bus-off recovery sequence again in the bus-off recovery sequence, reception error counter is cleared. Therefore it is necessary to detect 11 consecutive recessive-level bits 128 times on the bus again.





Figure 14-56 Bus-off recovery (Normal Operation Mode with ABT)

Caution When the transmission from the initialization mode to any operation modes is requested to execute bus-off recovery sequence again in the bus-off recovery sequence, reception error counter is cleared. Therefore it is necessary to detect 11 consecutive recessive-level bits 128 times on the bus again.







### Figure 14-58 Forced shutdown process

Caution If a

If a read/write access to any other register is executed by software (include EFSD bit setting becomes invalid and the GOM bit is not cleared. (refer to 14.7 (1) "CnGMCTRL - CANn global control register")



Figure 14-59 Error handling





Figure 14-60 Setting CPU stand-by (from CAN sleep mode)

bus.

Caution Before the CPU is set in the CPU standby mode, please check if the CAN sleep mode has been reached. However, after check of the CAN sleep mode, until the CPU is set in the CPU standby mode, the CAN sleep mode may be cancelled by wakeup from CAN





Figure 14-61 Setting CPU stand-by (from CAN stop mode)

Caution The CAN stop mode can only be released by writing  $01_B$  to the PSMODE[1:0] bit of the CnCTRL register and not by a change in the CAN bus state.



# Chapter 15 A/D Converter (ADC)

This microcontroller has two instances of the A/D Converter.

**Note** Throughout this chapter, the individual instances of the A/D Converter are identified by "n" (n = 0, 1). Each A/D Converter provides 10 channels, which are identified by "m" (m = 0 to 9).

## 15.1 Features

- Analog input: 2 × 10 channels (ANI00 to ANI09, ANI10 to ANI19)
- 10-bit resolution
- On-chip A/D conversion result register (ADCRn0 to ADCRn9): 10 bits × 10
- A/D conversion trigger mode
  - A/D trigger mode
  - Timer trigger mode
  - External trigger mode
- Successive approximation method
- DMA transfer support of A/D conversion result to internal RAM



## 15.2 Configuration

The A/D Converter adopts the successive approximation method.

## (1) Input circuit

The input circuit selects the analog input (ANIn0 to ANIn9) according to the mode set by the ADMn0, ADMn1, and ADMn2 registers.

## (2) C-Array

Holds the charge of the differential voltage between the voltage input from the analog input pins (ANIn0 to ANIn9) and the reference voltage (1/2 AV<sub>DD</sub>), and redistributes the sampled charges.

## (3) C-Dummy

This block holds the reference voltage (1/2  $\rm AV_{DD})$  and assigns the reference of the comparator input.

## (4) Voltage Comparator

The Voltage Comparator compares the C-Array comparison potential with the C-Dummy reference potential.

# (5) A/D conversion result register (ADCRnm), A/D conversion result register nH (ADCRnmH)

ADCRnm is a 10-bit register that holds A/D conversion results. Each time A/D conversion is completed, the conversion results are loaded from the successive approximation register (SAR).

RESET input makes this register undefined.

## (6) A/D conversion result register for DMA transfer (ADDMAn)

ADDMAn is a 16-bit register that holds the last 10-bit A/D conversion result and an overrun flag for indicating a DMA transfer failure.

## (7) ANIn0 to ANIn9 pins

These are 10-channel analog input pins for the A/D Converter n. They input the analog signals to be A/D converted.

**Caution** Make sure that the voltages input to ANIn0 to ANIn9 do not exceed the rated values. If a voltage higher than  $AV_{DD}$  or lower than  $AV_{SSn}$  (even within the range of the absolute maximum ratings) is input to a channel, the conversion value of the channel is undefined, and the conversion values of the other channels may also be affected.



## (8) AV<sub>REFn</sub> pins

This is the pin for inputting the reference voltage of the A/D Converter. It converts signals input to the ANIn0 to ANIn9 pins to digital signals based on the voltage applied between AV<sub>SSn</sub> and AV<sub>REFn</sub>.

## (9) AV<sub>SSn</sub> pin

This is the ground pin of the A/D Converter. Always use this pin at the same potential as that of the  $EV_{SS}$  pin even when the A/D Converter is not used.

## (10) AV<sub>DD</sub> pin

This is the analog power supply pin of both A/D Converters (ADC0, ADC1).



Figure 15-1 Block diagram of A/D Converter (ADCn)



| Caution | 1. If there is noise at the analog input pins (ANIn0 to ANIn9) or at the reference     |
|---------|----------------------------------------------------------------------------------------|
|         | voltage input pin (AV <sub>REFn</sub> ), that noise may generate an illegal conversion |
|         | result.                                                                                |
|         | Software processing will be needed to avoid a negative effect on the system            |
|         | from this illegal conversion result.                                                   |

An example of this software processing is shown below.

- Take the average result of a number of A/D conversions and use that as the A/D conversion result.
- Execute a number of A/D conversions consecutively and use those results, omitting any exceptional results that may have been obtained.
- 2. Do not apply a voltage outside the  $AV_{SSn}$  to  $AV_{REFn}$  range to the pins that are used as A/D Converter input pins.



## **15.3 Control Registers**

## (1) ADMn0 - A/D Converter mode register 0

The ADMn0 register is an 8-bit register that specifies the operation mode, and executes conversion operations.

Access This register can be read/written in 8-bit or 1-bit units. However, bit 6 can only be read. Writing this bit is ignored.

| Address | ADM00: | FFFFF200 <sub>H</sub> |
|---------|--------|-----------------------|
|         | ADM10: | FFFFF240 <sub>H</sub> |

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|       | 7     | 6     | 5   | 4   | 3 | 2  | 1 | 0 |
|-------|-------|-------|-----|-----|---|----|---|---|
| ADMn0 | ADCEn | ADCSn | BSn | MSn | 0 | 02 | 0 | 0 |
|       | R/W   | R     | R/W | R/W | R | R  | R | R |

**Caution 1.** When the ADCEn bit is 1 in the timer trigger mode and external trigger mode, the trigger signal standby state is set. To clear the ADCEn bit, write 0 or reset.

In A/D trigger mode (ADMn1.TRGn[1:0] =  $00_B$ ), the conversion trigger is set by writing 1 to the ADCEn bit. After the operation, when the mode is changed to the timer trigger mode or external trigger mode without clearing the ADCEn bit, the trigger input standby state is set immediately after changing the register.

2. The A/D conversion can be restarted by writing to ADMn0 while A/D conversion in enabled (ADMn0.ADCEn = 1).

In that case the conversion operation is initialized and conversion is executed from the beginning after the A/D converter stabilization time has elapsed.

Note that the BSn and MSn bits must not be changed while A/D conversion in enabled, thus the same values must be re-written to restart the conversion.

| Table 15-1 | ADMn0 r | egister | contents |
|------------|---------|---------|----------|
|------------|---------|---------|----------|

| Bit<br>position | Bit name | Function                                                                                                                         |
|-----------------|----------|----------------------------------------------------------------------------------------------------------------------------------|
| 7               | ADCEn    | Controls the A/D conversion operation of ADCn.<br>0: A/D conversion operation disabled.<br>1: A/D conversion operation enabled.  |
| 6               | ADCSn    | Indicates the A/D conversion status of ADCn.<br>0: A/D conversion of ADCn is stopped.<br>1: A/D conversion of ADCn is operating. |
| 5               | BSn      | Specifies the buffer mode of ADCn.<br>0: 1-buffer mode<br>1: 4-buffer mode                                                       |
| 4               | MSn      | Specifies the operationr mode of ADCn.<br>0: Scan mode<br>1: Scan mode                                                           |



The ADMn1 register is an 8-bit register that specifies the conversion operation time and trigger mode.

Access This register can be read/written in 8-bit or 1-bit units.

Address ADM01: FFFFF201<sub>H</sub> ADM11: FFFFF241<sub>H</sub>

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|       | 7     | 6     | 5     | 4     | 3 | 2  | 1    | 0    |
|-------|-------|-------|-------|-------|---|----|------|------|
| ADMn1 | EGAn1 | EGAn0 | TRGn1 | TRGn0 | 0 | 02 | FRn1 | FRn0 |
|       | R/W   | R/W   | R/W   | R/W   | R | R  | R/W  | R/W  |

**Caution** 1. Changing the setting of ADMn1 is prohibited while A/D conversion is enabled (ADMn0.ADCEn = 1).

 The A/D conversion can be restarted by writing to ADMn1 while A/D conversion in enabled (ADMn0.ADCEn = 1). In that case the conversion operation is initialized and conversion is executed from the beginning after the A/D converter stabilization time has elapsed. Note that the ADnM1 value must not be changed while A/D conversion in enabled, thus the same value must be re-written to restart the conversion.

| Table 15-2 | ADMn1 | register | contents | (1/2) |
|------------|-------|----------|----------|-------|
|------------|-------|----------|----------|-------|

| Bit<br>position | Bit name | Function     |              |                                                                |  |  |  |  |  |
|-----------------|----------|--------------|--------------|----------------------------------------------------------------|--|--|--|--|--|
| 7, 6            | EGAn1    | Specifies th | ne valid edg | e of the external trigger input (ADTRGn).                      |  |  |  |  |  |
|                 | EGAn0    | EGAn1        | EGAn0        | Valid Edge Specification of External Trigger Input<br>(ADTRGn) |  |  |  |  |  |
|                 |          | 0            | 0            | No edge detected (does not operate as external trigger)        |  |  |  |  |  |
|                 |          | 0            | 1            | Falling edge detected                                          |  |  |  |  |  |
|                 |          | 1            | 0            | Rising edge detected                                           |  |  |  |  |  |
|                 |          | 1            | 1            | Both edges, falling and rising edge detected                   |  |  |  |  |  |
|                 |          |              |              |                                                                |  |  |  |  |  |
| 5, 4            | TRGn1    | Specifies th | ne trigger m | ode of ADCn.                                                   |  |  |  |  |  |
|                 | TRGn0    | TRGn1        | TRGn0        | ADCn Trigger Mode Specification                                |  |  |  |  |  |
|                 |          | 0            | 0            | A/D trigger mode<br>(conversion starts with ADMn0.ADCEn = 1)   |  |  |  |  |  |
|                 |          | 0            | 1            | Timer trigger mode                                             |  |  |  |  |  |
|                 |          |              | 0            | External trigger mode                                          |  |  |  |  |  |
|                 |          | 1            | 1            | Setting prohibited                                             |  |  |  |  |  |
|                 |          |              |              |                                                                |  |  |  |  |  |



| Table 15-2 | ADMn1 | register | contents | (2/2) |
|------------|-------|----------|----------|-------|
|------------|-------|----------|----------|-------|

| Bit<br>position | Bit name | Function     |              |                                   |                                                                             |                                              |  |  |
|-----------------|----------|--------------|--------------|-----------------------------------|-----------------------------------------------------------------------------|----------------------------------------------|--|--|
| 1, 0            | FRn1     | Specifies th | ne conversio | n time of ADCn.                   |                                                                             |                                              |  |  |
|                 | FRn0     | FRn1         | FRn0         | Number of<br>conversion<br>clocks | Conversion<br>Operation<br>Time                                             | A/D<br>Stabilization<br>Time <sup>Note</sup> |  |  |
|                 |          | 0            | 0            | 32                                | 2.0 µs                                                                      | 1.0 µs                                       |  |  |
|                 |          | 0            | 1            | 64                                | 4.0 µs                                                                      | 2.0 µs                                       |  |  |
|                 |          | 1            | 0            | 96                                | 6.0 µs                                                                      | 2.5 µs                                       |  |  |
|                 |          | 1            | 1            | 128                               | 8.0 µs                                                                      | 2.5 µs                                       |  |  |
|                 |          | Others th    | an above     |                                   | Setting prohibited                                                          |                                              |  |  |
|                 |          | of t         | he A/D Conv  | verter, conversion is a           | rom 0 to 1, to secure t<br>started after the A/D s<br>nversion is executed. |                                              |  |  |



| (3)           | ADMn2 -                                                                                                                            | ADMn2 - A/D Converter mode register 2                                                                                                  |             |             |              |        |        |        |  |
|---------------|------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------|--------------|--------|--------|--------|--|
|               |                                                                                                                                    | The ADMn2 register is an 8-bit register that specifies the analog input pin of the A/D Converter n.                                    |             |             |              |        |        |        |  |
| Access        | This regis                                                                                                                         | ter can be                                                                                                                             | e read/writ | ten in 8-bi | t or 1-bit u | inits  |        |        |  |
| Address       | ADM02: FFFF202 <sub>H</sub><br>ADM12: FFFF242 <sub>H</sub>                                                                         |                                                                                                                                        |             |             |              |        |        |        |  |
| Initial Value | 00 <sub>H</sub> . This                                                                                                             | register is                                                                                                                            | cleared b   | by any res  | et.          |        |        |        |  |
|               | 7                                                                                                                                  | 6                                                                                                                                      | 5           | 4           | 3            | 2      | 1      | 0      |  |
| ADMn2         | 0                                                                                                                                  | 0                                                                                                                                      | 0           | 0           | ANISn3       | ANISn2 | ANISn1 | ANISn0 |  |
|               | R                                                                                                                                  | R                                                                                                                                      | R           | R           | R/W          | R/W    | R/W    | R/W    |  |
|               |                                                                                                                                    |                                                                                                                                        |             |             |              |        |        |        |  |
| Caution       | <ol> <li>If a channel for which no analog input pin exists is specified, the result of<br/>A/D conversion is undefined.</li> </ol> |                                                                                                                                        |             |             |              |        |        |        |  |
|               | •                                                                                                                                  | <ol> <li>Changing the setting of the ANISn3 to ANISn0 bits is prohibited while A/D conversion is enabled (ADMn0.ADCEn = 1).</li> </ol> |             |             |              |        |        |        |  |

3. The A/D conversion can be restarted by writing to ADMn1 while A/D conversion in enabled (ADMn0.ADCEn = 1). In that case the conversion operation is initialized and conversion is executed from the beginning after the A/D converter stabilization time has elapsed. Note that the ADnM2 value must not be changed while A/D conversion in

enabled, thus the same value must be re-written to restart the conversion.

| Bit<br>position | Bit name  |           | Function                                                    |          |   |                    |                |  |  |  |  |  |  |
|-----------------|-----------|-----------|-------------------------------------------------------------|----------|---|--------------------|----------------|--|--|--|--|--|--|
| 3 to 0          | ANIn[3:0] | Specifies | Specifies the analog input pins for A/D conversion of ADCn. |          |   |                    |                |  |  |  |  |  |  |
|                 |           | ANIn3     | ANIn3 ANIn2 ANIn2 ANIn0 A/D Conversion                      |          |   |                    |                |  |  |  |  |  |  |
|                 |           |           |                                                             |          |   | Select Mode        | Scan Mode      |  |  |  |  |  |  |
|                 |           | 0         | 0                                                           | 0        | 0 | ANIn0              | ANIn0          |  |  |  |  |  |  |
|                 |           | 0         | 0                                                           | 0        | 1 | ANIn1              | ANIn0, ANIn1   |  |  |  |  |  |  |
|                 |           | 0         | 0 0 1                                                       | 1        | 0 | ANIn2              | ANIn0 to ANIn2 |  |  |  |  |  |  |
|                 |           | 0         | 0                                                           | 1        | 1 | ANIn3              | ANIn0 to ANIn3 |  |  |  |  |  |  |
|                 |           | 0         | 1                                                           | 0        | 0 | ANIn4              | ANIn0 to ANIn4 |  |  |  |  |  |  |
|                 |           | 0         | 1                                                           | 0        | 1 | ANIn5              | ANIn0 to ANIn5 |  |  |  |  |  |  |
|                 |           | 0         | 1                                                           | 1        | 0 | ANIn6              | ANIn0 to ANIn6 |  |  |  |  |  |  |
|                 |           | 0         | 1                                                           | 1        | 1 | ANIn7              | ANIn0 to ANIn7 |  |  |  |  |  |  |
|                 |           | 1         | 0                                                           | 0        | 0 | ANIn8              | ANIn0 to ANIn8 |  |  |  |  |  |  |
|                 |           | 1         | 0                                                           | 0        | 1 | ANIn9              | ANIn0 to ANIn9 |  |  |  |  |  |  |
|                 |           |           | Others th                                                   | an above | • | Setting prohibited |                |  |  |  |  |  |  |

## Table 15-3 ADMn2 register contents



| (4) | ADTRSELn - A/D | Converter trigger | source select register |
|-----|----------------|-------------------|------------------------|
|-----|----------------|-------------------|------------------------|

The ADTRSELn register is an 8-bit register that specifies the timer trigger signal in the timer trigger mode (TRGn1, TRGn0 bits of ADMn1 register =  $01_B$ ).

Access This register can be read/written in 8-bit or 1-bit units

Address ADTRSEL0: FFFFF270<sub>H</sub> ADTRSEL1: FFFFF272<sub>H</sub>

| Initial Value 00 <sub>H</sub> . This register is cle | ared by any reset. |
|------------------------------------------------------|--------------------|
|------------------------------------------------------|--------------------|

|          | 7 | 6 | 5 | 4 | 3      | 2      | 1      | 0      |
|----------|---|---|---|---|--------|--------|--------|--------|
| ADTRSELn | 0 | 0 | 0 | 0 | TSELn3 | TSELn2 | TSELn1 | TSELn0 |
|          | R | R | R | R | R/W    | R/W    | R/W    | R/W    |

**Caution** Before changing the setting of the ADTRSELn register, stop the A/D conversion operation (by clearing the ADMn0.ADCEn bit to 0). The operation is not guaranteed if the setting of the ADTRSELn register is changed while A/D conversion is enabled (ADMn0.ADCEn = 1).

## Table 15-4 ADMn2 register contents

| Bit<br>position | Bit name   |           | Function                                                    |          |        |                                                   |  |  |  |  |  |  |  |
|-----------------|------------|-----------|-------------------------------------------------------------|----------|--------|---------------------------------------------------|--|--|--|--|--|--|--|
| 3 to 0          | TSELn[3:0] | Specifies | Specifies the analog input pins for A/D conversion of ADCn. |          |        |                                                   |  |  |  |  |  |  |  |
|                 |            | TSELn3    | TSELn2                                                      | TSELn1   | TSELn0 | Trigger Source Selection<br>in Timer Trigger Mode |  |  |  |  |  |  |  |
|                 |            | 0         | 0                                                           | 0        | 1      | TS0ADT0 signal (from TMS0)                        |  |  |  |  |  |  |  |
|                 |            | 0         | 0                                                           | 1        | 0      | TS0ADT1 signal (from TMS0)                        |  |  |  |  |  |  |  |
|                 |            | 0         | 0                                                           | 1        | 1      | TS1ADT0 signal (from TMS1)                        |  |  |  |  |  |  |  |
|                 |            | 0         | 1                                                           | 0        | 0      | TS1ADT1 signal (from TMS1)                        |  |  |  |  |  |  |  |
|                 |            | 0         | 1                                                           | 0        | 1      | INTTS0OD interrupt (from TMS0)                    |  |  |  |  |  |  |  |
|                 |            | 0         | 1                                                           | 1        | 0      | INTTS0CD interrupt (from TMS0)                    |  |  |  |  |  |  |  |
|                 |            | 0         | 1                                                           | 1        | 1      | INTTS1OD interrupt (from TMS1)                    |  |  |  |  |  |  |  |
|                 |            | 1         | 0                                                           | 0        | 0      | INTTS1CD interrupt (from TMS1)                    |  |  |  |  |  |  |  |
|                 |            |           | Others th                                                   | an above |        | Setting prohibited                                |  |  |  |  |  |  |  |



# (5) ADCRn0 to ADCRn9, ADCRn0H to ADCRn9H - A/D conversion result registers

The ADCRnm register is a 10-bit register holding the A/D conversion results.

Access These registers are read-only in 16-bit or 8-bit units.When 16-bit access is performed, the ADCRnm register is specified, and when 8 bit access is performed, the ADCRnmH register holding the higher 8 bits of the conversion result is specified

| Address | ADCR00: | FFFFF210 <sub>H</sub> | ADCR00H: | FFFFF211 <sub>H</sub> |
|---------|---------|-----------------------|----------|-----------------------|
|         | ADCR01: | FFFFF212 <sub>H</sub> | ADCR01H: | FFFFF213 <sub>H</sub> |
|         | ADCR02: | FFFFF214 <sub>H</sub> | ADCR02H: | FFFFF215 <sub>H</sub> |
|         | ADCR03: | FFFFF216 <sub>H</sub> | ADCR03H: | FFFFF217 <sub>H</sub> |
|         | ADCR04: | FFFFF218 <sub>H</sub> | ADCR04H: | FFFFF219 <sub>H</sub> |
|         | ADCR05: | FFFFF21A <sub>H</sub> | ADCR05H: | FFFFF21B <sub>H</sub> |
|         | ADCR06: | FFFFF21C <sub>H</sub> | ADCR06H: | FFFFF21D <sub>H</sub> |
|         | ADCR07: | FFFFF21E <sub>H</sub> | ADCR07H: | FFFFF21F <sub>H</sub> |
|         | ADCR08: | FFFFF220 <sub>H</sub> | ADCR08H: | FFFFF221 <sub>H</sub> |
|         | ADCR09: | FFFFF222 <sub>H</sub> | ADCR09H: | FFFFF223 <sub>H</sub> |
|         | ADCR10: | FFFFF250 <sub>H</sub> | ADCR10H: | FFFFF251 <sub>H</sub> |
|         | ADCR11: | FFFFF252 <sub>H</sub> | ADCR11H: | FFFFF253 <sub>H</sub> |
|         | ADCR12: | FFFFF254 <sub>H</sub> | ADCR12H: | FFFFF255 <sub>H</sub> |
|         | ADCR13: | FFFFF256 <sub>H</sub> | ADCR13H: | FFFFF257 <sub>H</sub> |
|         | ADCR14: | FFFFF258 <sub>H</sub> | ADCR14H: | FFFFF259 <sub>H</sub> |
|         | ADCR15: | FFFFF25A <sub>H</sub> | ADCR15H: | FFFFF25B <sub>H</sub> |
|         | ADCR16: | FFFFF25C <sub>H</sub> | ADCR16H: | FFFFF25D <sub>H</sub> |
|         | ADCR17: | FFFFF25E <sub>H</sub> | ADCR17H: | FFFFF25F <sub>H</sub> |
|         | ADCR18: | FFFFF260 <sub>H</sub> | ADCR18H: | FFFFF261 <sub>H</sub> |
|         | ADCR19: | FFFFF262 <sub>H</sub> | ADCR19H: | FFFFF263 <sub>H</sub> |

Initial Value Undefined

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 **ADCRnm** ADnm9 ADnm8 ADnm7 ADnm6 ADnm5 ADnm4 ADnm3 ADnm2 ADnm1 ADnm0 0 0 0 0 0 0 R R R R R R R R R R R R R R R R **ADCRnmH** 

**Note** When reading the 10-bit data of the A/D conversion results from the ADCRnm register, only the higher 10 bits are valid and the lower 6 bits are always read as 0.

|         | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| ADCRnmH | ADnm9 | ADnm8 | ADnm7 | ADnm6 | ADnm5 | ADnm4 | ADnm3 | ADnm2 |
|         | R     | R     | R     | R     | R     | R     | R     | R     |



The correspondence between each analog input pin and the ADCRnm register is shown in Table 15-5 below.

|                  | Assignment of A/D Conversion Result Registers |                      |  |  |  |  |  |  |  |
|------------------|-----------------------------------------------|----------------------|--|--|--|--|--|--|--|
| Analog Input Pin | Select 1 Buffer Mode/<br>Scan Mode            | Select 4 Buffer Mode |  |  |  |  |  |  |  |
| ANIn0            | ADCRn0, ADCRn0H                               | ADCRn0 to ADCRn3,    |  |  |  |  |  |  |  |
| ANIn1            | ADCRn1, ADCRn1H                               | ADCRn0H to ADCRn3H   |  |  |  |  |  |  |  |
| ANIn2            | ADCRn2, ADCRn2H                               |                      |  |  |  |  |  |  |  |
| ANIn3            | ADCRn3, ADCRn3H                               |                      |  |  |  |  |  |  |  |
| ANIn4            | ADCRn4, ADCRn4H                               | ADCRn4 to ADCRn7,    |  |  |  |  |  |  |  |
| ANIn5            | ADCRn5, ADCRn5H                               | ADCRn4H to ADCRn7H   |  |  |  |  |  |  |  |
| ANIn6            | ADCRn6, ADCRn6H                               |                      |  |  |  |  |  |  |  |
| ANIn7            | ADCRn7, ADCRn7H                               |                      |  |  |  |  |  |  |  |
| ANIn8            | ADCRn8, ADCRn8H                               | ADCRn0 to ADCRn3,    |  |  |  |  |  |  |  |
| ANIn9            | ADCRn9, ADCRn9H                               | ADCRn0H to ADCRn3H   |  |  |  |  |  |  |  |

### Table 15-5 Assignment of A/D conversion result registers to analog input pins

The relationship between the analog voltage input to the analog input pins (ANIn0 to ANIn9) and the A/D conversion result (of the A/D conversion result register (ADCRnm)) is as follows:

$$ADCR = INT \left( \frac{V_{IN}}{AV_{REF}} \times 1024 + 0.5 \right)$$

or,

$$(\text{ADCR} - 0.5) \times \frac{\text{AV}_{\text{REF}}}{1024} \le V_{\text{IN}} < (\text{ADCR} + 0.5) \times \frac{\text{AV}_{\text{REF}}}{1024}$$

| INT():              | Function that returns the integer value                                            |
|---------------------|------------------------------------------------------------------------------------|
| V <sub>IN</sub> :   | Analog input voltage                                                               |
| AV <sub>REF</sub> : | AV <sub>REF</sub> pin voltage                                                      |
| ADCR:               | Value of the upper 10 bit of the A/D conversion result register, i.e. ADCRnm[15:6] |

*Figure 15-2 on page 517* shows the relationship between the analog input voltage and the A/D conversion results.





Figure 15-2 Relationship between analog input voltage and A/D conversion results



#### ADDMAn - A/D conversion result register for DMA (6)

The ADDMAn register is a 16-bit register holding the result of the latest A/D conversion operation, and is used for DMA transfer of ADCn results into the internal RAM. It has an overrun detection flag indicating an overrun situation of the DMA transfer mechanism.

Access This register is read-only in 16-bit units.

| Address | ADDMA0: | FFFFF22E <sub>H</sub> |
|---------|---------|-----------------------|
|         | ADDMA1: | FFFFF26E <sub>H</sub> |

Initial Value Undefined

ADD

|      | 15          | 14          | 13          | 12          | 11          | 10          | 9           | 8           | 7           | 6           | 5 | 4 | 3 | 2 | 1 | 0    |
|------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|---|---|---|---|---|------|
| DMAn | ADDM<br>An9 | ADDM<br>An8 | ADDM<br>An7 | ADDM<br>An6 | ADDM<br>An5 | ADDM<br>An4 | ADDM<br>An3 | ADDM<br>An2 | ADDM<br>An1 | ADDM<br>An0 | 0 | 0 | 0 | 0 | 0 | ODFn |
|      | R           | R           | R           | R           | R           | R           | R           | R           | R           | R           | R | R | R | R | R | R    |

Caution Do not read the ADDMAn register by CPU during DMA transfer activities. If this register is read by CPU, overflow detection cannot be ensured.

### Table 15-6 ADDMAn register contents

| Bit<br>position | Bit name        | Function                                                                                                                                                |                                                                                                       |  |  |  |  |  |  |  |
|-----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 15 to 6         | ADDMAn<br>[9:0] | Returns the recent A/D conversion result of ADCn required for DMA transfer                                                                              |                                                                                                       |  |  |  |  |  |  |  |
|                 |                 | ADDMAn[9:0]                                                                                                                                             | A/D Conversion Result for DMA Transfer                                                                |  |  |  |  |  |  |  |
|                 |                 | 000 <sub>H</sub> to 3FF <sub>H</sub>                                                                                                                    | Value of the recent A/D conversion result                                                             |  |  |  |  |  |  |  |
| 0               | ODFn            | <ul> <li>0: No A/D conversion result</li> <li>1: At least one A/D conversion ADDMAn register.</li> <li>The ODFn flag is used for in results.</li> </ul> | <ul> <li>The ODFn flag is used for indicating a DMA transfer failure of the A/D conversion</li> </ul> |  |  |  |  |  |  |  |



# 15.4 Operation

## 15.4.1 Basic operation

A/D conversion is executed by the following procedure.

 The selection of the analog input and specification of the operation mode, trigger mode, etc. should be specified using the ADMn0, ADMn1 or ADMn2 registers<sup>Note 1</sup>.

When the ADCEn bit of the ADMn0 register is set to 1, A/D conversion starts in the A/D trigger mode. In the timer trigger mode and external trigger mode, the trigger standby state<sup>Note 2</sup> is set.

- 2. When A/D conversion is started, the C-array voltage on the analog input side and the C-array voltage on the reference side are compared by the comparator.
- 3. When the comparison of the 10 bits ends, the conversion results are stored in the ADCRnm register. When A/D conversion has been performed the specified number of times, the A/D conversion end interrupt (INTADn) is generated.
- **Note** 1. If the setting of the ADMn0, ADMn1 or ADMn2 registers is changed during A/D conversion, the operation immediately before is stopped, and the result of the conversion is not stored in the ADCRnm register. The A/D conversion operation is then initialized, and conversion is executed from the beginning again.
  - During the timer trigger mode and external trigger mode, if the ADCEn bit of the ADMn0 register is set to 1, the mode changes to the trigger standby state. The A/D conversion operation is started by the trigger signal (ADCSn bit in the ADMn0 register = 1), and the trigger standby state (ADCSn bit = 0) is returned when the A/D conversion operation ends.



## 15.4.2 Operation mode and trigger mode

Various conversion operations can be specified for the A/D Converter by specifying the operation mode and trigger mode. The operation mode and trigger mode are set by the ADMn0 and ADMn1registers.

The following table shows the relationship between the operation mode and trigger mode.

### Table 15-7 Relationship between operation mode and trigger mode

| Trigger Mode     | Operation Mode |           | Register Set Value |           |
|------------------|----------------|-----------|--------------------|-----------|
| ingger wode      |                |           | ADMn0              | ADMn1     |
| A/D trigger      | Select         | 1 buffer  | xx010000B          | xx0000xxB |
|                  |                | 4 buffers | xx110000B          |           |
|                  | Scan           | •         | xx000000B          |           |
| Timer trigger    | Select         | 1 buffer  | xx010000B          | xx0100xxB |
|                  |                | 4 buffers | xx110000B          |           |
|                  | Scan           | •         | xx000000B          |           |
| External trigger | Select         | 1 buffer  | xx010000B          | xx1000xxB |
|                  |                | 4 buffers | xx110000B          |           |
|                  | Scan           |           | xx000000B          |           |

### (1) Trigger mode

There are three types of trigger modes that serve as the start timing of A/D conversion processing: A/D trigger mode, timer trigger mode, and external trigger mode. These trigger modes are set by the TRGn1 and TRGn0 bits of the ADMn1 register.

### • A/D trigger mode

This mode starts the conversion timing of the analog input set to the ANIn0 to ANIn9 pins, and by setting the ADMn0.ADCEn bit to 1, starts A/D conversion. Unless the ADCEn bit is cleared to 0 after conversion, the next conversion operation is repeated. If data is written to the ADMn0 to ADMn2 registers during conversion, conversion is stopped and then executed from the beginning again.

#### • Timer trigger mode

This mode specifies the conversion timing of the analog input set for the ANIn0 to ANIn9 pins using signals from the inverter timer S (TMS0, TMS1). The ADTRSELn register specifies the analog input conversion timing by selecting one of the A/D Converter trigger signals connected to the 16-bit inverter timer S (TMS0, TMS1).

If the ADMn0.ADCEn bit is set to 1, the A/D Converter waits for an event input, and starts conversion when the event occurs (ADMn0.ADCSn = 1). When conversion has finished, the converter waits for an event input again (ADMn0.ADCSn bit = 0). If data is written to the ADMn0 to ADMn2 registers during conversion, conversion is stopped and then executed from the beginning again.



### External trigger mode

This mode specifies the conversion timing of the analog input to the ANIn0 to ANIn9 pins using the ADTRGn pin.

The EGAn1 and EGAn0 bits of the ADMn1 register are used to specify the valid edge to be input to the ADTRGn pin.

When the ADMn0.ADCEn bit is set to 1, the A/D Converter waits for an external trigger (ADTRGn), and starts conversion when the valid edge of ADTRGn is detected (ADMn0.ADCSn bit = 1). When the converter has finished its conversion operation, it waits for an external trigger again (ADMn0.ADCSn bit = 0).

If the valid edge is detected at the ADTRGn pin during conversion, conversion is executed from the beginning again.

If data is written to the ADMn0 to ADMn2 registers during conversion, conversion is stopped and then executed from the beginning again.

## (2) Operation mode

There are two operation modes that set the ANIn0 to ANIn9 pins: select mode and scan mode. The select mode has sub-modes that consist of 1-buffer mode and 4-buffer mode. These modes are set by the BSn and MSn bits of the ADMn0 register.

## Select mode

In this mode, one analog input specified by the ADMn2 register is A/D converted. The conversion results are stored in the ADCRnm register corresponding to the analog input (ANInm). For this mode, the 1-buffer mode and 4-buffer mode are provided for storing the A/D conversion results.



## 1-buffer mode

In this mode, one analog input specified by the ADM2 register is A/D converted. The conversion results are stored in the ADCRnm register corresponding to the analog input (ANInm). The ANInm and ADCRnm register correspond one to one, and an A/D conversion end interrupt (INTADn) is generated each time one A/D conversion ends. After conversion has finished, the next conversion operation is repeated, unless the ADMn0.ADCEn bit is cleared to 0.



Figure 15-3 Select mode operation timing: 1-buffer mode (conversion of ANIn1 in A/D trigger mode)

RENESAS

## 4-buffer mode

In this mode, one analog input is A/D converted and the results are stored in the ADCRnm registers. The A/D conversion end interrupt (INTADn) is generated when the four A/D conversions end (m = 0 to 3 when one of the analog input channels ANIn0 to ANIn3 is specified, m = 4 to 7 when one of analog input channels ANIn4 to ANIn7 is specified, and m = 0 to 3 when one of the analog input channels ANIn8 or ANIn9 is specified).

After conversion has finished, the next conversion operation is repeated, unless the ADMn0.ADCEn bit is cleared to 0.



Figure 15-4 Select mode operation timing: 4-buffer mode (conversion of ANIn2 in A/D trigger mode)



### Scan mode

In this mode, the analog inputs specified by the ADMn2 register are selected sequentially from the ANIn0 pin, and A/D conversion is executed. The A/D conversion results are stored in the ADCRnm register corresponding to the analog input. When the conversion of the specified analog input ends, the A/D conversion end interrupt (INTADn) is generated. After conversion has finished, the next conversion operation is repeated, unless the ADMn0.ADCEn bit is cleared to 0.



Figure 15-5 Scan mode operation timing: 4-channel scan (conversion of ANI0 to ANI3 in A/D trigger mode)



## 15.5 Operation in A/D Trigger Mode

When the ADMn0.ADCEn bit is set to 1, A/D conversion is started.

## 15.5.1 Select mode operation

In this mode, the analog input specified by the ADMn2 register is A/D converted. The conversion results are stored in the ADCRnm register corresponding to the analog input. In the select mode, the 1-buffer mode and 4-buffer mode are supported according to the storing method of the A/D conversion results.

## (1) 1-buffer mode (A/D trigger select: 1 buffer)

In this mode, one analog input is A/D converted once. The conversion results are stored in one ADCRn register. The analog input and ADCRn register correspond one to one.

Each time an A/D conversion is executed, an A/D conversion end interrupt (INTAD) is generated and A/D conversion ends. The next conversion operation is repeated, unless the ADMn0.ADCE bit is cleared to 0.

### Table 15-8 Correspondence between analog input pins and ADCRnm register (A/D trigger select: 1 buffer)

| Analog Input | A/D Conversion Result Register |  |
|--------------|--------------------------------|--|
| ANInm        | ADCRnm                         |  |

This mode is most appropriate for applications in which the results of each first-time A/D conversion are read.



Figure 15-6 Example of 1-buffer mode operation (A/D trigger select: 1 buffer)

- 1. The ADMn0.ADCEn bit is set to 1 (enable)
- 2. ANIn2 is A/D converted
- 3. The conversion result is stored in ADCRn2 register
- 4. The INTAD interrupt is generated

RENESAS

### (2) 4-buffer mode (A/D trigger select: 4 buffers)

In this mode, one analog input is A/D converted four times and the results are stored in the ADCRnm register. When the 4th A/D conversion ends, an A/D conversion end interrupt (INTADn) is generated and the A/D conversion is stopped. The next conversion operation is repeated, unless the ADMn0.ADCEn bit is cleared to 0.

# Table 15-9Correspondence between analog input pins and ADCRnm register<br/>(A/D trigger select: 4 buffers)

| Analog Input | A/D Conversion Result Register |  |
|--------------|--------------------------------|--|
| ANI0 to ANI3 | ADCRn0 (1st time)              |  |
|              | ADCRn1 (2nd time)              |  |
|              | ADCRn2 (3rd time)              |  |
|              | ADCRn3 (4th time)              |  |
| ANI4 to ANI7 | ADCRn4 (1st time)              |  |
|              | ADCRn5 (2nd time)              |  |
|              | ADCRn6 (3rd time)              |  |
|              | ADCRn7 (4th time)              |  |
| ANIn8, ANIn9 | ADCRn0 (1st time)              |  |
|              | ADCRn1 (2nd time)              |  |
|              | ADCRn2 (3rd time)              |  |
|              | ADCRn3 (4th time)              |  |

This mode is suitable for applications in which the average of the A/D conversion results is calculated.



Figure 15-7 Example of 4-buffer mode operation (A/D trigger select: 4 buffers)

- 1. The ADMn0.ADCEn bit is set to 1 (enable)
- 2. ANIn3 is A/D converted
- 3. The conversion result is stored in ADCRn0 register
- 4. ANIn3 is A/D converted
- 5. The conversion result is stored in ADCRn1 register
- 6. ANIn3 is A/D converted
- 7. The conversion result is stored in ADCRn2 register
- 8. ANIn3 is A/D converted



- 9. The conversion result is stored in ADCRn3 register
- 10. The INTAD interrupt is generated

## 15.5.2 Scan mode operation

In this mode, the analog inputs specified by the ADMn2 register are selected sequentially from the ANIn0 pin, and A/D conversion is executed. The A/D conversion results are stored in the ADCRnm register corresponding to the analog input.

When conversion of all the specified analog input ends, the A/D conversion end interrupt (INTADn) is generated, and A/D conversion is stopped. The next conversion operation is repeated, unless the ADMn0.ADCEn bit is cleared to 0.

### Table 15-10 Correspondence between analog input pins and ADCRnm register (A/D trigger scan)

| Analog Input          | A/D Conversion Result Register |
|-----------------------|--------------------------------|
| ANIn0                 | ADCRn0                         |
|                       | ·<br>·                         |
| ANInm <sup>Note</sup> | ADCRnm                         |

Note Set by the ADMn2.ANISn[3:0] bits.

This mode is most appropriate for applications in which multiple analog inputs are constantly monitored.



Figure 15-8 Example of scan mode operation (A/D trigger scan)

- 1. The ADMn0.ADCEn bit is set to 1 (enable)
- 2. ANIn0 is A/D converted
- 3. The conversion result is stored in ADCRn0
- 4. ANIn1 is A/D converted
- 5. The conversion result is stored in ADCRn1
- 6. ANIn2 is A/D converted
- 7. The conversion result is stored in ADCRn2
- 8. ANIn3 is A/D converted
- 9. The conversion result is stored in ADCRn3



- 10. ANIn4 is A/D converted
- 11. The conversion result is stored in ADCRn4
- 12. ANIn5 is A/D converted
- 13. The conversion result is stored in ADCRn5
- 14. The INTAD interrupt is generated



## 15.6 Operation in Timer Trigger Mode

In this mode, the conversion timing of the analog input signal set by the ANIn0 to ANIn9 pins is defined by a timer event signal.

The analog input conversion timing is generated when an A/D Converter trigger signal from the timers is generated.

When the ADMn0.ADCEn bit is set to 1, the A/D Converter waits for the timer signal and starts conversion when the timer event occurs (ADMn0.ADCSn = 1). When conversion is finished, the converter waits for a timer event signal again (ADMn0.ADCSn = 0).

If the timer event signal occurs during conversion, the conversion operation is executed from the beginning again.

If data is written to the ADMn0 to ADMn2 registers during conversion, the conversion operation is stopped and executed from the beginning again.

## 15.6.1 Select mode operation

In this mode, an analog input (ANIn0 to ANIn9) specified by the ADMn2 register is A/D converted. The conversion results are stored in the ADCRnm register corresponding to the analog input. In the select mode, the 1-buffer mode and 4-buffer mode are provided according to the storing method of the A/D conversion results.

### (1) 1-buffer mode operation (timer trigger select: 1 buffer)

In this mode, one analog input is A/D converted once and the conversion results are stored in one ADCRnm register.

One analog input is A/D converted once using the trigger of the timer event signals and the results are stored in one ADCRnm register. An A/D conversion end interrupt (INTADn) is generated for each A/D conversion.

Unless the ADMn0.ADCEn bit is cleared to 0, A/D conversion is repeated each time a timer event signal is generated.

#### Table 15-11 Correspondence between analog input pins and ADCRnm register (1-buffer mode (timer trigger select: 1 buffer))

| Trigger            | Analog Input | A/D Conversion Result Register |
|--------------------|--------------|--------------------------------|
| Timer event signal | ANIn0        | ADCRn0                         |
|                    | ANIn1        | ADCRn1                         |
|                    | ANIn2        | ADCRn2                         |
|                    | ANIn3        | ADCRn3                         |
|                    | ANIn4        | ADCRn4                         |
|                    | ANIn5        | ADCRn5                         |
|                    | ANIn6        | ADCRn6                         |
|                    | ANIn7        | ADCRn7                         |
|                    | ANIn8        | ADCRn8                         |
|                    | ANIn9        | ADCRn9                         |





Figure 15-9 Example of 1-buffer mode operation (timer trigger select: 1 buffer) (ANIn1)

- 1. The ADMn0.ADCEn is set to 1 (enable)
- 2. The TS0ADT0 signal is generated
- 3. ANIn1 is A/D converted
- 4. The conversion result is stored in ADCRn1
- 5. The INTADn interrupt is generated



### (2) 4-buffer mode operation (timer trigger select: 4 buffers)

In this mode, A/D conversion of one analog input is executed four times, and the results are stored in the ADCRnm register.

One analog input is A/D converted four times using the timer event signals as a trigger, and the results are stored in four ADCRnm registers. The A/D conversion end interrupt (INTADn) is generated when the four A/D conversions end.

After conversion has finished, the next conversion is repeated when a timer event signal is generated, unless the ADMn0.ADCEn bit is cleared to 0.

This mode is suitable for applications in which the average of the A/D conversion results is calculated.

# Table 15-12Correspondence between analog input pins and ADCRnm register<br/>(4-buffer mode (timer trigger select: 4 buffers))

| Trigger            | Analog Input | A/D Conversion Result Register |
|--------------------|--------------|--------------------------------|
| Timer event signal | ANI0 to ANI3 | ADCRn0 (1st time)              |
|                    |              | ADCRn1 (2nd time)              |
|                    |              | ADCRn2 (3rd time)              |
|                    |              | ADCRn3 (4th time)              |
|                    | ANI4 to ANI7 | ADCRn4 (1st time)              |
|                    |              | ADCRn5 (2nd time)              |
|                    |              | ADCRn6 (3rd time)              |
|                    |              | ADCRn7 (4th time)              |
|                    | ANIn8, ANIn9 | ADCRn0 (1st time)              |
|                    |              | ADCRn1 (2nd time)              |
|                    |              | ADCRn2 (3rd time)              |
|                    |              | ADCRn3 (4th time)              |



Figure 15-10 Example of 4-buffer mode operation (timer trigger select: 4 buffers) (ANIn3)

- 1. The ADMn0.ADCEn bit is set to 1 (enable)
- 2. TheTS0ADT0 signal is generated
- 3. ANIn3 is A/D converted
- 4. The conversion result is stored in ADCR0



- 5. ANIn3 is A/D converted
- 6. The conversion result is stored in ADCR1
- 7. ANIn3 is A/D converted
- 8. The conversion result is stored in ADCR2
- 9. ANIn3 is A/D converted
- 10. The conversion result is stored in ADCR3
- 11. The INTADn interrupt is generated

## 15.6.2 Scan mode operation

In this mode, the analog inputs specified by the ADMn2 register are selected sequentially from the ANIn0 pin and are A/D converted the specified number of times using the timer event signal as a trigger.

The result of conversion is stored in the ADCRnm register corresponding to the analog input. When all the specified analog input signals have been converted, an A/D conversion end interrupt (INTADn) occurs.

After conversion has finished, the A/D Converter waits for a trigger unless the ADMn0.ADCEn bit is cleared to 0. When a timer event occurs again, the converter starts A/D conversion again, starting from the ANIn0 input.

This mode is most appropriate for applications in which multiple analog inputs are constantly monitored.

# Table 15-13Correspondence between analog input pins and ADCRnm register<br/>(scan mode (timer trigger scan))

| Trigger            | Analog Input | A/D Conversion Result Register |
|--------------------|--------------|--------------------------------|
| Timer event signal | ANIn0        | ADCRn0                         |
|                    | ANIn1        | ADCRn1                         |
|                    | ANIn2        | ADCRn2                         |
|                    | ANIn3        | ADCRn3                         |
|                    | ANIn4        | ADCRn4                         |
|                    | ANIn5        | ADCRn5                         |
|                    | ANIn6        | ADCRn6                         |
|                    | ANIn7        | ADCRn7                         |
|                    | ANIn8        | ADCRn8                         |
|                    | ANIn9        | ADCRn9                         |





Figure 15-11 Example of scan mode operation (timer trigger scan) (ANIn0 to ANIn4)

- 1. The ADMn0.ADCEn bit is set to 1 (enable)
- 2. The TS0ADT0 signal is generated
- 3. ANIn0 is A/D converted
- 4. The conversion result is stored in ADCRn0
- 5. ANIn1 is A/D converted
- 6. The conversion result is stored in ADCRn1
- 7. ANIn2 is A/D converted
- 8. The conversion result is stored in ADCRn2
- 9. ANIn3 is A/D converted
- 10. The conversion result is stored in ADCRn3
- 11. ANIn4 is A/D converted
- 12. The conversion result is stored in ADCRn4
- 13. The INTADn interrupt is generated



## 15.7 Operation in External Trigger Mode

In this mode, the conversion timing of the analog signals input to the ANIn0 to ANIn9 pins is specified by the ADTRGn pin.

Detection of the valid edge at the ADTRGn input pin is specified by using the EGAn1 and EGAn0 bits of the ADMn1 register.

When the ADMn0.ADCEn bit is set to 1, the A/D Converter waits for an external trigger (ADTRGn), and starts conversion when the valid edge of ADTRGn is detected (ADMn0.ADCSn = 1). When the converter has ended conversion, it waits for the external trigger again (ADMn0.ADCSn = 0).

If the valid edge is detected at the ADTRGn pin during conversion, conversion is executed from the beginning again.

If data is written to the ADMn0 to ADMn2 registers during conversion, conversion is stopped and executed from the beginning again.

## 15.7.1 Select mode operation

In this mode, one analog input (ANIn0 to ANIn9) specified by the ADMn2 register is A/D converted. The conversion results are stored in the ADCRnm register corresponding to the analog input. In the select mode, there are two select modes: 1-buffer mode and 4-buffer mode, according to the storing method of the conversion results.

## (1) 1-buffer mode (external trigger select: 1 buffer)

In this mode, one analog input is A/D converted using the ADTRGn signal as a trigger. The conversion results are stored in one ADCRnm register. The analog input and the A/D conversion results register correspond one to one. The A/D conversion end interrupt (INTADn) is generated for each A/D conversion, and A/D conversion is stopped.

#### Table 15-14 Correspondence between analog input pins and ADCRnm register (external trigger select: 1 buffer)

| Trigger       | Analog Input | A/D Conversion Result Register |
|---------------|--------------|--------------------------------|
| ADTRGn signal | ANInm        | ADCRnm                         |

While the ADMn0.ADCEn = 1, A/D conversion is repeated every time a trigger is input from the ADTRGn pin.

This mode is most appropriate for applications in which the results are read after each A/D conversion.





Figure 15-12 Example of 1-buffer mode operation (external trigger select: 1 buffer) (ANIn1)

- 1. The ADMn0.ADCEn bit is set to 1 (enable)
- 2. The external trigger is generated
- 3. ANIn1 is A/D converted
- 4. The conversion result is stored in ADCRn1
- 5. The INTADn interrupt is generated

## (2) 4-buffer mode (external trigger select: 4 buffers)

In this mode, one analog input is A/D converted four times using the ADTRGn signal as a trigger and the results are stored in the ADCRnm register. The A/D conversion end interrupt (INTADn) is generated and A/D conversion is stopped after the 4th A/D conversion.

# Table 15-15Correspondence between analog input pins and ADCRnm register<br/>(external trigger select: 4 buffers))

| Trigger       | Analog Input | A/D Conversion Result Register |
|---------------|--------------|--------------------------------|
| ADTRGn signal | ANI0 to ANI3 | ADCRn0 (1st time)              |
|               |              | ADCRn1 (2nd time)              |
|               |              | ADCRn2 (3rd time)              |
|               |              | ADCRn3 (4th time)              |
|               | ANI4 to ANI7 | ADCRn4 (1st time)              |
|               |              | ADCRn5 (2nd time)              |
|               |              | ADCRn6 (3rd time)              |
|               |              | ADCRn7 (4th time)              |
|               | ANIn8, ANIn9 | ADCRn0 (1st time)              |
|               |              | ADCRn1 (2nd time)              |
|               |              | ADCRn2 (3rd time)              |
|               |              | ADCRn3 (4th time)              |

While the ADCEn bit of the ADMn0 register is 1, A/D conversion is repeated every time a trigger is input from the ADTRGn pin.



### Chapter 15

This mode is suitable for applications in which the average of the A/D conversion results is calculated.



Figure 15-13 Example of 4-buffer mode operation (external trigger select: 4 buffers) (ANIn2)

- 1. The ADMn0.ADCEn bit is set to 1 (enable)
- 2. The external trigger is generated
- 3. ANIn2 is A/D converted
- 4. The conversion result is stored in ADCRn0
- 5. ANIn2 is A/D converted
- 6. The conversion result is stored in ADCRn1
- 7. ANIn2 is A/D converted
- 8. The conversion result is stored in ADCRn2
- 9. ANIn2 is A/D converted
- 10. The conversion result is stored in ADCRn3
- 11. The INTAD interrupt is generated

## 15.7.2 Scan mode operation

In this mode, the analog inputs specified by the ADMn2 register are selected sequentially from the ANIn0 pin using the ADTRGn signal as a trigger, and A/D converted. The A/D conversion results are stored in the ADCRnm register corresponding to the analog input ANInm.

When conversion of all the specified analog inputs has ended, the A/D conversion end interrupt (INTADn) is generated. Unless the ADMn0.ADCE bit is cleared to 0 after end of conversion, the A/D Converter waits for a trigger. The converter starts A/D conversion from the ANIn0 input when a trigger is input to the ADTRGn pin again.

When a trigger is input to the ADTRGn pin while ADMn0.ADCEn = 1, A/D conversion is started again.

This is most appropriate for applications in which multiple analog inputs are constantly monitored.

RENESAS

## Table 15-16 Correspondence between analog input pins and ADCRnm register (external trigger scan)

| Trigger       | Analog Input | A/D Conversion Result Register |
|---------------|--------------|--------------------------------|
| ADTRGn signal | ANIn0        | ADCRn0                         |
|               | ANIn1        | ADCRn1                         |
|               | ANIn2        | ADCRn2                         |
|               | ANIn3        | ADCRn3                         |
|               | ANIn4        | ADCRn4                         |
|               | ANIn5        | ADCRn5                         |
|               | ANIn6        | ADCRn6                         |
|               | ANIn7        | ADCRn7                         |
|               | ANIn8        | ADCRn8                         |
|               | ANIn9        | ADCRn9                         |





- 1. The ADMn0.ADCEn bit is set to 1 (enable)
- 2. The external trigger is generated
- 3. ANIn0 is A/D converted
- 4. The conversion result is stored in ADCRn0
- 5. ANIn1 is A/D converted
- 6. The conversion result is stored in ADCRn1
- 7. ANIn2 is A/D converted
- 8. The conversion result is stored in ADCRn2
- 9. ANIn3 is A/D converted
- 10. The conversion result is stored in ADCRn3
- 11. The INTADn interrupt is generated



## 15.8 Precautions

## (1) Stopping conversion operation

When the ADMn0.ADCEn bit is cleared to 0 during a conversion operation, the conversion operation stops and the conversion results are not stored in the ADCRnm register.

## (2) External/timer trigger interval

Set the interval (input time interval) of the trigger in the external or timer trigger mode longer than the conversion time specified by the ADMn1.FRnm bits and the number of conversion channels specified by the ADMn2.ANISn[3:0] bits:

## $0 < interval \leq (ANISn[3:0] + 1) * Conversion Operation Time (FRn1, FRn0)$

When the following external trigger or timer trigger is input during a conversion operation, the conversion operation is aborted and the conversion starts according to the last external trigger input or timer trigger input.

When conversion operations are aborted, the conversion results are not stored in the ADCRnm register. However, the number of times the trigger has been input is counted. When an interrupt occurs, the values that have been converted are stored in the ADCRnm register.

## (3) Operation in HALT mode

A/D conversion continues in the HALT mode. When this mode is released by NMI input or unmasked maskable interrupt input, the ADMn0, ADMn1, and ADMn2 registers as well as the ADCRnm register hold the value.

## (4) Input range of ANIn0 to ANIn9

Use the input voltage at ANIn0 to ANIn9 within the specified range. If a voltage outside the range of  $AV_{REF}$  is input to any of these pins (even within the absolute maximum rating range), the converted value of the channel is undefined. In addition, the converted value of the other channels may also be affected.

## (5) Conflicts

### Conflict between writing A/D conversion result registers (ADCRnm, ADCRnmH) at end of conversion and reading ADCRnm and ADCRnmH registers by instruction

Reading the ADCRnm and ADCRnmH registers takes precedence. After these registers have been read, the new conversion result is written to the ADCRnm and ADCRnmH registers.

 Conflict between writing ADCRnm and ADCRnmH at end of conversion and input of external trigger signal

The external trigger signal is not accepted during A/D conversion. Therefore, it is not accepted while ADCRnm and ADCRnmH are being written.

• Conflict between writing ADCRnm and ADCRnmH at end of conversion and writing ADMn1 or ADMn2 register

RENESAS

If ADMn1 or ADMn2 register is written immediately after ADCRnm and ADCRnmH have been written on completion of A/D conversion, the conversion result is written to the ADCRnm and ADCRnmH registers, but the A/D conversion end interrupt (INTADn) may not occur depending on the timing.

# (6) Unexpected AD conversion start in timer trigger mode/external trigger mode

**Description** If the ADC is operated in timer trigger mode (ADMn1.TRGn[1:0] =  $01_B$ ) or in external trigger mode (ADMn1.TRGn[1:0] =  $10_B$ ) the ADC may start conversion autonomously on changing the AD conversion enable bit (ADMn0.ADCEn) from 0 to 1 before occurence of the first configured trigger event (timer trigger or external trigger).

Workaround Whenever changing the ADC enable bit (ADMn0.ADCEn) from 0 to 1 write two times in sequence 1 to the ADC enable bit.

Make sure that no maskable or non-maskable interrupt may occur between the 1st and 2nd write instruction. Use the processor status word to temporarily disable non-maskable interrupts (PSW.NP = 1) or non-maskable interrupts (PSW.ID = 1) if interrupt occurence cannot be excluded.

- Save PSW (optional)
- Disable INT and/or NMI (optional)
- 1st write 1 to ADMn0.ADCEn (byte or bit access)
- 2nd write 1 to ADMn0.ADCEn (byte or bit access)
- Restore PSW (optional)

## Example (C - GHS Compiler):

unsigned int tmp;

```
tmp=__GETSR(); // Save PSW
__SETSR(0x000000a0|tmp);// Disable NMI and INT in PSW
ADM00 = 0x80; // 1st write to ADMn0
ADM00 = 0x80; // 2nd write to ADMn0
__SETSR(tmp); // Restore PSW
```

## Example (ASM):

```
      stsr PSW, r14
      -- Save PSW

      mov 0x000000a0, r13

      or r14, r13

      ldsr r13, PSW
      -- Disable NMI and INT in PSW

      set1 7, ADM00[r0]
      -- 1st write to ADMn0

      set1 7, ADM00[r0]
      -- 2nd write to ADMn0

      ldsr r14, PSW
      -- Restore PSW
```

**Note** This workaround is effective only in case code is executed from internal flash memory. While debugging do not set a breakpoint on the 2nd write instruction to ADMn0.



### (7) Restart of conversion operation

When A/D conversion is stopped (aborted) and restarted by

- clearing and setting the ADCEn bit  $(1 \rightarrow 0 \rightarrow 1)$
- rewriting one of the ADMn0, ADMn1, or ADMn2 registers (with same value)

a ADCRnm register should be read not before the corresponding channel has been converted the first time.

The end of conversion of all channels is indicated by the occurrence of INTADn interrupt. Therefore read the ADCRnm registers within an interrupt service routine (ISR), or if no interrupt is serviced, check the conversion end by checking the indicating IF flag of the corresponding interrupt control register (ADICn).

A DMA transfer of the conversion results can be executed at any time and does not need to observe the end of conversion.

### Example (when no ISR is applied):

Initialization/ Reconfiguration

```
// stop ADC
ADMn0.ADCEn = 0;
// reconfigure ADC
...
// clear request flag & start ADC
ADICn.IF = 0;
ADMn0.ADCEn = 1;
...
```

• Asynchronous read

```
// check request flag
// (or wait until it is set)
if (ADICn.IF == 1)
{
    // read ADCRnm registers
    ...
}
...
```



# Chapter 16 16-Bit Timer/Event Counter AA (TAA)

The microcontroller has ten instances of this 16-bit timer/event counter AA, TAA0 to TAA9. The timer is upward compatible to Timer P used in various other devices of the V850E and the V850ES family, including V850E/PHC3. It offers new additional features for enhanced output control and for 32-bit capture.

Throughout this chapter, the individual instances of Timer AA are identified by "n" (n = 0 to 9), for example, TAAnCTL0 for the TAAn control register 0.

## 16.1 Features

Timer AA (TAA) is a 16-bit timer/event counter provided with general-purpose functions.

TAA can perform the following operations:

- 16-bit-accuracy PWM output timer
- Interval timer
- External event counter function
- Timer synchronised operation function
- One-shot pulse output
- · Pulse interval and frequency measurement counter
- Free running function
- · External trigger pulse output function

## 16.2 Function Outline

- Capture trigger input signal × 2
- External trigger input signal × 1
- Clock select × 8
- External event count input × 1
- Readable counter × 1
- Capture/compare reload register × 2
- Capture/compare match interrupt × 2
- Timer output (TOAAn0, TOAAn1) × 2
- 32-bit capture by cascading two timer AA (TAA0+TAAx, TAA4+TAAy, TAA8+TAA9).

Note x = 1 to 3 and y = 5 to 7



## 16.3 Configuration

TAA includes the following hardware.

#### Table 16-1 Timer TAA registers and external connections

| Item                      | Configuration                                                      |  |  |  |  |
|---------------------------|--------------------------------------------------------------------|--|--|--|--|
| Timer register            | 16-bit counter                                                     |  |  |  |  |
| Registers                 | TAAn timer capture/compare registers 0, 1     (TAAnCCR0, TAAnCCR1) |  |  |  |  |
|                           | TAAn timer read buffer register (TAAnCNT)                          |  |  |  |  |
|                           | CCR0 buffer register, CCR1 buffer register                         |  |  |  |  |
| Input selection registers | TAAn input selection registers (TAAIC0 to TAAIC2)                  |  |  |  |  |
| Timer output              | TOAAn0, TOAAn1                                                     |  |  |  |  |
| Timer input               | TIAAn0, TIAAn1, TTRGAAn, TEVTAAn                                   |  |  |  |  |
| Control registers         | TAAn control registers 0, 1 (TAAnCTL0, TAAnCTL1)                   |  |  |  |  |
|                           | TAAn I/O control registers 0 to 3 (TAAnIOC0, TAAnIOC2, TAAnIOC4)   |  |  |  |  |
|                           | • TAAn option registers 0, 1 (TAAnOPT0, TAAnOPT1)                  |  |  |  |  |
|                           | TAAn Specific overflow value control register (TAAnSVC)            |  |  |  |  |

Note n = 0 to 9

Timer AA (TAA) pins are alternate function of port pins. For how to set the alternate function, refer to the description of the registers in *"Pin Functions" on page 23*.

The block diagram of the timer TAA is shown below. *Figure 16-2* and *Figure 16-3* show the block diagrams of the input circuits of the different timers TAAn.





Figure 16-1 Block Diagram of Timer AA

Note 1. n = 0 to 9

2. PCLKn: peripheral clocks (refer to "Clock Generator" on page 148):

| PCLK    | 0  | 1  | 2 | 3 | 4 | 5 | 7    | 9      |
|---------|----|----|---|---|---|---|------|--------|
| f [MHz] | 32 | 16 | 8 | 4 | 2 | 1 | 0.25 | 0.0625 |





Figure 16-2 Input circuit of TAA0 (left) and TAAm with m = 1, 2, 5, 6 (right)



Figure 16-3 Input circuit of TAA3 (left) and TAA4 (right)





Figure 16-4 Input circuit of TAA7 (left) and TAA8 (right)



Figure 16-5 Input circuit of TAA9



| •                          |                                                                                                                                    | •                                         |  |  |  |  |  |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|--|--|--|--|--|
| (1)                        | TAAnCCR0 - TAA capture/compare register 0                                                                                          |                                           |  |  |  |  |  |
|                            | The TAAnCCR0 register is a 16-bit register that o register or as a compare register.                                               | perates either as capture                 |  |  |  |  |  |
|                            | In free-running mode, this register can be used a compare register specified by bit TAAnOPT0.TAA                                   |                                           |  |  |  |  |  |
|                            | In the pulse width measurement mode, this register can be used only as a capture register (the compare function cannot be used.)   |                                           |  |  |  |  |  |
|                            | In all modes other than free-running mode and pulse width measurement mode, this register is used as a compare register.           |                                           |  |  |  |  |  |
|                            | After reset the TAAnCCR0 register default status                                                                                   | is compare register.                      |  |  |  |  |  |
| Access                     | This register can be read/written in 16-bit units.                                                                                 |                                           |  |  |  |  |  |
| Address                    | TAA0CCR0: FFFF606 <sub>H</sub> TAA1CCF                                                                                             | 80: FFFFF616 <sub>H</sub>                 |  |  |  |  |  |
|                            | TAA2CCR0: FFFF626 <sub>H</sub> TAA3CCF                                                                                             | 10: FFFFF636 <sub>H</sub>                 |  |  |  |  |  |
|                            | TAA4CCR0: FFFF646 <sub>H</sub> TAA5CCF                                                                                             | 80: FFFFF656 <sub>H</sub>                 |  |  |  |  |  |
|                            |                                                                                                                                    | 80: FFFFF676 <sub>H</sub>                 |  |  |  |  |  |
|                            | TAA8CCR0: FFFF686 <sub>H</sub> TAA9CCF                                                                                             | 80: FFFF6B6 <sub>H</sub>                  |  |  |  |  |  |
| Initial Value              | $0000_{\text{H}}$ . This registers is cleared by any reset, or if the internal operation clock is disabled by TAAnCTL0.TAAnCE = 0. |                                           |  |  |  |  |  |
|                            | 15 14 13 12 11 10 9 8 7 6                                                                                                          | 5 4 3 2 1 0                               |  |  |  |  |  |
| TAAnCCR0                   | Compare value 0                                                                                                                    |                                           |  |  |  |  |  |
|                            | R/W                                                                                                                                |                                           |  |  |  |  |  |
| Caution                    | When external event counter mode is used, do no 0000H.                                                                             | ot set TAAnCCR0 register to               |  |  |  |  |  |
| Use as compare<br>register | When used as a compare register, TAAnCCR0 ca<br>TAAnCE = 1, as shown below:                                                        | an be rewritten when                      |  |  |  |  |  |
|                            | TAA operation mode                                                                                                                 | TAAnCCR0 register writing<br>method       |  |  |  |  |  |
|                            | PWM mode, external trigger pulse output mode Re                                                                                    | eload                                     |  |  |  |  |  |
|                            | Free-running mode, external event count mode,<br>one-shot pulse mode, interval timer modeAr                                        | ny time write                             |  |  |  |  |  |
|                            |                                                                                                                                    | ot applicable<br>sed as capture register) |  |  |  |  |  |
| Use as capture<br>register | When used as capture register, the count value is capture trigger (TIAAn0) input edge detection.                                   | stored in TAAnCCR0 upon                   |  |  |  |  |  |
| N I.                       |                                                                                                                                    |                                           |  |  |  |  |  |

**Note** The value of TAAnCCR0 register is read when TAAnCE bit of TAAn control register 0 (TAAnCTL0) equals 1.



Not applicable

(used as capture register)

| '                          |                                                                                                                                  | ,                                                                                                                                                       |  |  |  |  |  |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| (2)                        | TAAnCCR1 - TAA capture/compare register                                                                                          | r 1                                                                                                                                                     |  |  |  |  |  |
|                            | The TAAnCCR1 register is a 16-bit register that capture register or as a compare register.                                       | at operates either both as a                                                                                                                            |  |  |  |  |  |
|                            | In free-running mode, this register can be used compare register specified by bit TAAnOPT0.T                                     |                                                                                                                                                         |  |  |  |  |  |
|                            | In the pulse width measurement mode, this register can be used only as a capture register (the compare function cannot be used.) |                                                                                                                                                         |  |  |  |  |  |
|                            | In all modes other than free-running mode and pulse width measurement mode, this register is used as a compare register.         |                                                                                                                                                         |  |  |  |  |  |
|                            | After reset the TAAnCCR1 register default status is compare register.                                                            |                                                                                                                                                         |  |  |  |  |  |
| Access                     | This register can be read/written in 16-bit units                                                                                |                                                                                                                                                         |  |  |  |  |  |
| Address                    | TAA2CCR1: FFFF628TAA3CTAA4CCR1: FFFF648TAA5CTAA6CCR1: FFFF668TAA7C                                                               | CCR1: FFFFF618 <sub>H</sub><br>CCR1: FFFFF638 <sub>H</sub><br>CCR1: FFFFF658 <sub>H</sub><br>CCR1: FFFFF678 <sub>H</sub><br>CCR1: FFFFF688 <sub>H</sub> |  |  |  |  |  |
| Initial Value              | $0000_{\text{H}}$ . This register is cleared by any reset, or disabled by TAAnCTL0.TAAnCE = 0.                                   | r if the internal operation clock is                                                                                                                    |  |  |  |  |  |
|                            |                                                                                                                                  | 6 5 4 3 2 1 0                                                                                                                                           |  |  |  |  |  |
| TAAnCCR1                   | Compare value                                                                                                                    | 0                                                                                                                                                       |  |  |  |  |  |
|                            | R/W                                                                                                                              |                                                                                                                                                         |  |  |  |  |  |
| Caution                    | When external event counter mode is used, do 0000H.                                                                              | o not set TAAnCCR1 register to                                                                                                                          |  |  |  |  |  |
| Use as compare<br>register | When used as a compare register TAAnCCR1 can be rewritten when TAAnCE = 1, as below mentioned.                                   |                                                                                                                                                         |  |  |  |  |  |
|                            | TAA operation mode                                                                                                               | TAAnCCR1 register writing<br>method                                                                                                                     |  |  |  |  |  |
|                            | PWM mode, external trigger pulse output mode                                                                                     | Reload                                                                                                                                                  |  |  |  |  |  |
|                            | Free-running mode, external event count mode, one-shot pulse mode, interval timer mode                                           | Any time write                                                                                                                                          |  |  |  |  |  |

register

Note



Use as capture When used as a capture register the count value is stored in TAAnCCR1 upon

The value of TAAnCCR1 register is read when TAAnCE bit of TAAn control

capture trigger (TIAAn1) input edge detection.

Pulse width measurement mode

register 0 (TAAnCTL0) equals 1.

| (3)           | TAAn              | TAAnCNT - TAA counter read buffer register                                     |        |       |        |        |        |       |         |            |     |      |     |   |   |   |
|---------------|-------------------|--------------------------------------------------------------------------------|--------|-------|--------|--------|--------|-------|---------|------------|-----|------|-----|---|---|---|
|               | TAAn              | AAnCNT register is a read buffer register that can read 16-bit counter values. |        |       |        |        |        | ues.  |         |            |     |      |     |   |   |   |
| Access        | This r            | egis                                                                           | ter ca | an be | e read | d only | / in 1 | 6-bit | units   |            |     |      |     |   |   |   |
| Address       | TAA0              | TAA0CNT: FFFFF60A <sub>H</sub> TAA1CNT: FFFFF61A <sub>H</sub>                  |        |       |        |        |        |       |         |            |     |      |     |   |   |   |
|               | TAA2              | CNT                                                                            | : Fl   | FFFF  | 62A    | 4      |        |       | TAA     | BCNT       | : F | FFFF | 63A | 4 |   |   |
|               | TAA4              | AA4CNT: FFFF64A <sub>H</sub> TAA5CNT: FFFF65A <sub>H</sub>                     |        |       |        |        |        |       |         |            |     |      |     |   |   |   |
|               | TAA6              | CNT                                                                            | : Fl   | FFF   | 66A    | 4      |        |       | TAA7    | <b>CNT</b> | : F | FFFF | 67A | 4 |   |   |
|               | TAA8              | CNT                                                                            | : Fl   | FFF   | 68A    | -      |        |       | TAAS    | ONT        | : F | FFFF | 6BA | H |   |   |
| Initial Value | 0000 <sub>F</sub> | <sub>1</sub> . Th                                                              | is re  | giste | r is c | leare  | d by   | any r | eset.   |            |     |      |     |   |   |   |
|               |                   |                                                                                |        |       |        |        |        |       |         |            |     |      |     |   |   |   |
|               | 15                | 14                                                                             | 13     | 12    | 11     | 10     | 9      | 8     | 7       | 6          | 5   | 4    | 3   | 2 | 1 | 0 |
| TAAnCNT       |                   |                                                                                |        |       |        |        | С      | ounte | er valu | ie         |     |      |     |   |   |   |
|               |                   |                                                                                |        |       |        |        |        | F     | 3       |            |     |      |     |   |   |   |
|               |                   |                                                                                |        |       |        |        |        |       |         |            |     |      |     |   |   |   |

**Note** 0000H is read from this register, when TAAnCTL0.TAAnCE = 0. The current counter value is read when TAAnCE bit = 1.



## 16.4 Input Selection Registers

#### (1) TAAIC0 - Timer input control register 0

The TAAIC0 register is an 8-bit register that controls the external input pin source of the capture register 1 of TAA0 to TAA3.

Access This register can be read/written in 8-bit or 1-bit units.

Address FFFFF6F0<sub>H</sub>

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|        | 7   | 6       | 5   | 4   | 3       | 2       | 1       | 0       |
|--------|-----|---------|-----|-----|---------|---------|---------|---------|
| TAAIC0 | 0   | TAAIC06 | 0   | 0   | TAAIC03 | TAAIC02 | TAAIC01 | TAAIC00 |
|        | R/W | R/W     | R/W | R/W | R/W     | R/W     | R/W     | R/W     |
|        |     |         |     |     |         |         |         |         |

Caution Do not change the timer input when the timer is in operation.

#### Table 16-2 TAAIC0 register contents

| Bit<br>position | Bit name | Function                                                                                                                                                      |
|-----------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6               | TAAIC06  | Selects the TAA0CCR0 register capture source input.<br>0: Capture source input is pin P10/TIAA00/TEVTAA1<br>1: Capture source input is pin P16/TIAA30/TTRGAA2 |
| 3               | TAAIC03  | Selects the TAA3CCR1 register capture source input.<br>0: Capture source input is pin P17/TIAA31/TEVTAA2<br>1: Capture source input is pin P16/TIAA30/TTRGAA2 |
| 2               | TAAIC02  | Selects the TAA1CCR1 register capture source input.<br>0: Capture source input is pin P15/TIAA21/TTRGAA3<br>1: Capture source input is pin P14/TIAA20/TEVTAA3 |
| 1               | TAAIC01  | Selects the TAA1CCR1 register capture source input.<br>0: Capture source input is pin P13/TIAA11/TEVTAA0<br>1: Capture source input is pin P12/TIAA10/TTRGAA0 |
| 0               | TAAIC00  | Selects the TAA0CCR1 register capture source input.<br>0: Capture source input is pin P11/TIAA01/TTRGAA1<br>1: Capture source input is pin P10/TIAA00/TEVTAA1 |



#### (2) TAAIC1 - Timer input control register 1

The TAAIC1 register is an 8-bit register that controls the external input pin source of the capture register 1 of TAA4 to TAA7, as well as the internal time trigger source from the CAN Controllers to both capture registers 0 and 1 of TAA7.

Access This register can be read/written in 8-bit or 1-bit units.

Address FFFF6F1<sub>H</sub>

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|        | 7   | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|--------|-----|---------|---------|---------|---------|---------|---------|---------|
| TAAIC1 | 0   | TAAIC16 | TAAIC15 | TAAIC14 | TAAIC13 | TAAIC12 | TAAIC11 | TAAIC10 |
|        | R/W | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     | R/W     |

**Caution** Do not change the timer input when the timer is in operation.

#### Table 16-3 TAAIC0 register contents

| Bit<br>position | Bit name |             |                                                                                                                                                               | Function                                                                                                |  |  |  |  |
|-----------------|----------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|--|--|--|--|
| 6               | TAAIC16  | 0: Capture  | Selects the TAA4CCR0 register capture source input.<br>0: Capture source input is pin P20/TIAA40/TEVTAA5<br>1: Capture source input is RXDC                   |                                                                                                         |  |  |  |  |
| 5, 3            | TAAIC15  | Selects the | TAA7CCR                                                                                                                                                       | 1 register capture source input                                                                         |  |  |  |  |
|                 | TAAIC13  | TAAIC15     | TAAIC13                                                                                                                                                       | TAA7CCR1 Register Capture Source Input Selection                                                        |  |  |  |  |
|                 |          | 0           | 0                                                                                                                                                             | Capture source input is pin P27/TIAA71/ TEVTAA6                                                         |  |  |  |  |
|                 |          | 0           | 1                                                                                                                                                             | Capture source input is pin P26/TIAA70/ TTRGAA6                                                         |  |  |  |  |
|                 |          | 1           | 0                                                                                                                                                             | Capture source input is CAN1 time trigger (TSOUT1)                                                      |  |  |  |  |
|                 |          | 1           | 1                                                                                                                                                             |                                                                                                         |  |  |  |  |
| 4               | TAAIC14  | 0: Capture  | e source inp                                                                                                                                                  | D register capture source input.<br>Dut is pin P26/TIAA70/ TTRGAA6<br>Dut is CAN0 time trigger (TSOUT0) |  |  |  |  |
| 2               | TAAIC12  | 0: Capture  | e source inp                                                                                                                                                  | 1 register capture source input.<br>out is pin P25/TIAA61/TTRGAA7<br>out is pin P24/TIAA60/TEVTAA7      |  |  |  |  |
| 1               | TAAIC11  | 0: Capture  | Selects the TAA5CCR1 register capture source input.<br>0: Capture source input is pin P23/TIAA51/TEVTAA4<br>1: Capture source input is pin P22/TIAA50/TTRGAA4 |                                                                                                         |  |  |  |  |
| 0               | TAAIC10  | 0: Capture  | Selects the TAA4CCR1 register capture source input.<br>0: Capture source input is pin P21/TIAA41/TTRGAA5<br>1: Capture source input is pin P20/TIAA40/TEVTAA5 |                                                                                                         |  |  |  |  |



#### (3) TAAIC2 - Timer input control register 2

The TAAIC2 register is an 8-bit register that controls the external input pin source of the capture register 1 of TMT0 and TMT1, as well as the internal source of both capture registers 0 and 1 of TAA8 and TAA9.

Access This register can be read/written in 8-bit or 1-bit units.

Address FFFFF6F2<sub>H</sub>

**Initial Value** 00<sub>H</sub>. This register is cleared by any reset.

|        | 7       | 6       | 5       | 4       | 3   | 2       | 1       | 0       |
|--------|---------|---------|---------|---------|-----|---------|---------|---------|
| TAAIC2 | TAAIC27 | TAAIC26 | TAAIC25 | TAAIC24 | 0   | TAAIC22 | TAAIC21 | TAAIC20 |
|        | R/W     | R/W     | R/W     | R/W     | R/W | R/W     | R/W     | R/W     |

Caution Do not change the timer input when the timer is in operation.

#### Table 16-4 TAAIC0 register contents

| Bit<br>position | Bit name           |                                                                                                                                                          | Function                                                         |               |                                                           |                         |                              |  |
|-----------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|---------------|-----------------------------------------------------------|-------------------------|------------------------------|--|
| 7, 5, 2         | TAAIC27<br>TAAIC25 | Selects the                                                                                                                                              | TAA8CCR(                                                         | ) and TAA8    | CCR1 registers cap                                        |                         |                              |  |
|                 | TAAIC22            | TAAIC22 TAAIC25                                                                                                                                          |                                                                  | TAAIC27       | Capture So                                                | urce Input Selection of |                              |  |
|                 |                    | TAAIC22                                                                                                                                                  | TAAIC25                                                          | TAAIGZT       | TAA8CCR0                                                  |                         | TAA8CCR1                     |  |
|                 |                    | 0                                                                                                                                                        | Х                                                                | х             | INTT0CC0 signal f<br>TMT0                                 | from                    | INTT0CC1 signal from<br>TMT0 |  |
|                 |                    |                                                                                                                                                          | 0                                                                | 0             | Pin P100/TIAA80/<br>TTRGAA8                               |                         | Pin P101/TIAA81/<br>TEVTAA8  |  |
|                 |                    | 1                                                                                                                                                        | 0                                                                | 1             | Pin P100/TIAA80/                                          | T TRO                   | GAA8                         |  |
|                 |                    |                                                                                                                                                          | 1                                                                | 0             | TSTESG signal from TMS0                                   |                         | Pin P101/TIAA81/<br>TEVTAA8  |  |
|                 |                    |                                                                                                                                                          | 1                                                                | 1             | TSTESG signal fro                                         | om TN                   | 1S0                          |  |
| 6, 4            | TAAIC26<br>TAAIC24 | Selects the                                                                                                                                              | Selects the TAA9CCR0 and TAA9CCR1 registers capture source input |               |                                                           |                         |                              |  |
|                 | 17 U UOL 1         | TAAIC26                                                                                                                                                  | TAAIC24                                                          |               | Capture Source I                                          | nput                    | Selection of                 |  |
|                 |                    | TAAIC20                                                                                                                                                  | TAAIC24                                                          | Т             | AA9CCR0                                                   |                         | TAA9CCR1                     |  |
|                 |                    | 0                                                                                                                                                        | 0                                                                | Pin P102/     | TIAA90/TTRGAA9                                            | Pin I                   | P103/TIAA91/TEVTAA9          |  |
|                 |                    | 0                                                                                                                                                        | 1                                                                |               |                                                           | Pin I                   | P102/TIAA90/TTRGAA9          |  |
|                 |                    | 1                                                                                                                                                        | 0                                                                | TSTESG 9      | signal from TMS1                                          | Pin I                   | P103/TIAA91/TEVTAA9          |  |
|                 |                    | 1                                                                                                                                                        | 1                                                                |               |                                                           | TST                     | ESG signal from TMS1         |  |
| 1               | TAAIC21            | Selects the TT1CCR1 register capture source input.<br>0: Capture source input is pin P74/TIT11/TEVTT0<br>1: Capture source input is pin P73/TIT10/TTRGT0 |                                                                  |               |                                                           |                         |                              |  |
| 0               | TAAIC20            | 0: Captur                                                                                                                                                | e source inp                                                     | out is pin P7 | oture source input.<br>71/TIT01/TTRGT1<br>70/TIT00/TEVTT1 |                         |                              |  |



## 16.5 Control Registers

#### (1) TAAnCTL0 - TAA control register 0

TAAn control register 0 is an 8-bit register that controls the operation of timer AA.

Access This register can be read/written in 8-bit or 1-bit units.

| Address | TAA0CTL0: FFFFF600 <sub>H</sub> | TAA1CTL0: FFFFF610 <sub>H</sub> |
|---------|---------------------------------|---------------------------------|
|         | TAA2CTL0: FFFFF620 <sub>H</sub> | TAA3CTL0: FFFFF630 <sub>H</sub> |
|         | TAA4CTL0: FFFFF640 <sub>H</sub> | TAA5CTL0: FFFFF650 <sub>H</sub> |
|         | TAA6CTL0: FFFFF660 <sub>H</sub> | TAA6CTL0: FFFFF670 <sub>H</sub> |
|         | TAA8CTL0: FFFFF680 <sub>H</sub> | TAA7CTL0: FFFFF6B0 <sub>H</sub> |

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|          | 7      | 6   | 5   | 4   | 3   | 2        | 1        | 0        |
|----------|--------|-----|-----|-----|-----|----------|----------|----------|
| TAAnCTL0 | TAAnCE | 0   | 0   | 0   | 0   | TAAnCKS2 | TAAnCKS1 | TAAnCKS0 |
|          | R/W    | R/W | R/W | R/W | R/W | R/W      | R/W      | R/W      |

Caution Set bits TAAnCKS2 to TAAnCKS0 only when TAAnCE = 0. When TAAnCE bit setting is changed from 0 to 1, TAAnCKS2 to TAAnCKS0 bits can be set simultaneously. The same value can always be written to the TAAnCTL0 register by software.

#### Table 16-5 TAAnCTL0 register contents

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                       |           |                                |  |  |  |  |
|-----------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|--------------------------------|--|--|--|--|
| 7               | TAAnCE   | Controls the timer TAAn operation.<br>0: Internal operating clock operation disabled (TAAn is asynchronously reseted)<br>1: Internal operating clock operation enabled<br>Internal operating clock control and TAAn asynchronous reset are performed with the |                                                                                                                                                                                                                                                                       |           |                                |  |  |  |  |
|                 |          | stops (fixed to<br>When the TAA                                                                                                                                                                                                                               | TAAnCE bit. When TAAnCE bit is cleared to 0, the internal operating clock of TAAn stops (fixed to low level) and TAAn is reset asynchronously.<br>When the TAAnCE bit is set to 1, the internal operating clock is enabled within 2 input clocks, and TAAn counts up. |           |                                |  |  |  |  |
| 2 to 0          | TAAnCKS  | Selects the co                                                                                                                                                                                                                                                | unt clock of tin                                                                                                                                                                                                                                                      | ner TAAn. |                                |  |  |  |  |
|                 | [2:0]    | TAAnCKS2                                                                                                                                                                                                                                                      | TAAnCKS1                                                                                                                                                                                                                                                              | TAAnCKS0  | Internal count clock selection |  |  |  |  |
|                 |          | 0                                                                                                                                                                                                                                                             | 0                                                                                                                                                                                                                                                                     | 0         | PCLK0                          |  |  |  |  |
|                 |          | 0                                                                                                                                                                                                                                                             | 0                                                                                                                                                                                                                                                                     | 1         | PCLK1                          |  |  |  |  |
|                 |          | 0                                                                                                                                                                                                                                                             | 1                                                                                                                                                                                                                                                                     | 0         | PCLK2                          |  |  |  |  |
|                 |          | 0                                                                                                                                                                                                                                                             | 1                                                                                                                                                                                                                                                                     | 1         | PCLK3                          |  |  |  |  |
|                 |          | 1                                                                                                                                                                                                                                                             | 0                                                                                                                                                                                                                                                                     | 0         | PCLK4                          |  |  |  |  |
|                 |          | 1                                                                                                                                                                                                                                                             | PCLK5                                                                                                                                                                                                                                                                 |           |                                |  |  |  |  |
|                 |          | 1                                                                                                                                                                                                                                                             | 1                                                                                                                                                                                                                                                                     | 0         | PCLK7                          |  |  |  |  |
|                 |          | 1                                                                                                                                                                                                                                                             | 1                                                                                                                                                                                                                                                                     | 1         | PCLK9                          |  |  |  |  |



| (2)           | TAAnCTL1 - TAA timer control register 1                                                                                                                                                      |                                                                                       |                                                     |                        |                          |                         |                      |         |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|-----------------------------------------------------|------------------------|--------------------------|-------------------------|----------------------|---------|
|               | TAAn cont<br>timer AA.                                                                                                                                                                       | TAAn control register 1 is an 8-bit register that controls the operation of timer AA. |                                                     |                        |                          |                         |                      |         |
| Access        | This regis                                                                                                                                                                                   | ter can be                                                                            | e read/writt                                        | ten in 8-b             | it or 1-bit ι            | units.                  |                      |         |
| Address       | TAA0CTL1:FFFF601_HTAA1CTL1:FFFF611_HTAA2CTL1:FFFFF621_HTAA3CTL1:FFFFF631_HTAA4CTL1:FFFFF641_HTAA5CTL1:FFFFF651_HTAA6CTL1:FFFFF661_HTAA6CTL1:FFFFF671_HTAA8CTL1:FFFFF681_HTAA7CTL1:FFFFF6B1_H |                                                                                       |                                                     |                        |                          |                         |                      |         |
| Initial Value | 00 <sub>H</sub> . This                                                                                                                                                                       | register is                                                                           | cleared b                                           | y any res              | et.                      |                         |                      |         |
|               | 7                                                                                                                                                                                            | 6                                                                                     | 5                                                   | 4                      | 3                        | 2                       | 1                    | 0       |
| TAAnCTL1      | TAAnSYE                                                                                                                                                                                      | TAAnEST                                                                               | TAAnEEE                                             | 0                      | 0                        | TAAnMD2                 | TAAnMD1              | TAAnMD0 |
|               | R/W                                                                                                                                                                                          | R/W                                                                                   | R/W                                                 | R                      | R                        | R/W                     | R/W                  | R/W     |
| Caution       | (Despite c                                                                                                                                                                                   | is not gua<br>of this the                                                             | and TAAnN<br>aranteed if<br>same valu<br>takenly pe | rewriting<br>le can be | is perform<br>written wh | ied when T<br>ien TAAnC | TAAnCE =<br>CE = 1.) | : 1.    |

| Table 16-6 | TAAnCTL1 | register contents (1 | /2) |
|------------|----------|----------------------|-----|
|------------|----------|----------------------|-----|

again.

| Bit<br>position | Bit name |                                                                                                                                                                                                                                                                                               | Funct                                                            | ion                                                                        |            |
|-----------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|----------------------------------------------------------------------------|------------|
| 7               | TAAnSYE  | <ul> <li>Controls the tuned operation mode of timer TAAn.</li> <li>0: Independent operation mode (asynchronous operation mode</li> <li>1: Tuned operation mode (specification of slave operation)<br/>In this mode, timer TAAn can operate in synchronization with a master timer.</li> </ul> |                                                                  |                                                                            |            |
|                 |          | Master timer                                                                                                                                                                                                                                                                                  |                                                                  | Slave timer                                                                |            |
|                 |          | TAA0                                                                                                                                                                                                                                                                                          | TAA1                                                             | TAA2                                                                       | TAA3       |
|                 |          | TAA4                                                                                                                                                                                                                                                                                          | TAA5                                                             | TAA6                                                                       | TAA7       |
|                 |          |                                                                                                                                                                                                                                                                                               | clear the TAA0SY                                                 | E and TAA4SYE bits                                                         |            |
|                 |          | in the PW<br>mode, and<br>The slave<br>Setting the                                                                                                                                                                                                                                            | M mode, external to<br>d free-running mode<br>timers can be used | rigger pulse output r<br>e.<br>d in the free-running<br>unt mode, one-shot | mode only. |



| Bit<br>position | Bit name        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                 | Fund           | ction                              |  |  |
|-----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------------------------------------|--|--|
| 6               | TAAnEST         | <ul> <li>Controls the software trigger of timer TAAn.</li> <li>0: No operation</li> <li>1: In one-shot pulse mode: One-shot pulse software trigger<br/>In external trigger pulse output mode: Pulse output software trigger</li> <li>The TAAnEST bit functions as a software trigger in the one-shot pulse mode or<br/>external trigger pulse output mode (this bit is invalid in any other mode). By setting<br/>TAAnEST to 1 when TAAnCE = 1, a software trigger is issued. Therefore, be sure to<br/>set TAAnEST to 1 after setting TAAnCE = 1. The TTRGAAn pin is used for an external<br/>trigger.</li> <li>Note: The read value of the TAAnEST bit is always 0.</li> </ul> |                                                                                                                                                                                                                                                                                                                                                 |                |                                    |  |  |
| 5               | TAAnEEE         | 0: Use the in<br>1: Use extern<br>The valid edge<br>TAAnEEE bit =<br>Note: The re                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Selects the count clock input of timer TAAn.<br>0: Use the internal clock (clock selected by TAAnCTL0.TAAnCKS[2:0] bits)<br>1: Use external clock (TEVTAAn input edge)<br>The valid edge is specified with TAAnEES1 and TAAnEES0 bits when<br>TAAnEEE bit = 1 (external clock TEVTAAn).<br>Note: The read value of the TAAnEST bit is always 0. |                |                                    |  |  |
| 2 to 0          | TAAnMD<br>[2:0] | Selects the op                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | eration mode                                                                                                                                                                                                                                                                                                                                    | of timer TAAn. |                                    |  |  |
|                 | [2.0]           | TAAnMD2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | TAAnMD1                                                                                                                                                                                                                                                                                                                                         | TAAnMD0        | Timer mode selection               |  |  |
|                 |                 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0                                                                                                                                                                                                                                                                                                                                               | 0              | Interval timer mode                |  |  |
|                 |                 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0                                                                                                                                                                                                                                                                                                                                               | 1              | External event counter mode        |  |  |
|                 |                 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1                                                                                                                                                                                                                                                                                                                                               | 0              | External trigger pulse output mode |  |  |
|                 |                 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1                                                                                                                                                                                                                                                                                                                                               | 1              | One-shot pulse mode                |  |  |
|                 |                 | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0                                                                                                                                                                                                                                                                                                                                               | 0              | PWM mode                           |  |  |
|                 |                 | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0                                                                                                                                                                                                                                                                                                                                               | 1              | Free-running mode                  |  |  |
|                 |                 | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1                                                                                                                                                                                                                                                                                                                                               | 0              | Pulse width measurement mode       |  |  |
|                 |                 | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1                                                                                                                                                                                                                                                                                                                                               | 1              | Setting prohibited                 |  |  |
|                 |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                 |                |                                    |  |  |

## Table 16-6 TAAnCTL1 register contents (2/2)

**Note** n = 0 to 9



Α

#### (3) TAAnIOC0 - TAA dedicated I/O control register 0

The TAAnIOC0 register is an 8-bit register that controls the timer output.

Access This register can be read/written in 8-bit or 1-bit units.

| ddress | TAA0IOC0: | FFFF602 <sub>H</sub> | TAA1IOC0: | FFFFF612 <sub>H</sub> |
|--------|-----------|----------------------|-----------|-----------------------|
|        | TAA2IOC0: | FFFF622 <sub>H</sub> | TAA3IOC0: | FFFFF632 <sub>H</sub> |
|        | TAA4IOC0: | FFFF642 <sub>H</sub> | TAA5IOC0: | FFFFF652 <sub>H</sub> |
|        | TAA6IOC0: | FFFF662 <sub>H</sub> | TAA7IOC0: | FFFFF672 <sub>H</sub> |
|        | TAA8IOC0: | FFFF682 <sub>H</sub> | TAA9IOC0: | FFFF6B2 <sub>H</sub>  |
|        |           |                      |           |                       |

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|          | 7 | 6 | 5 | 4 | 3       | 2       | 1       | 0       |
|----------|---|---|---|---|---------|---------|---------|---------|
| TAAnIOC0 | 0 | 0 | 0 | 0 | TAAnOL1 | TAAnOE1 | TAAnOL0 | TAAnOE0 |
|          | R | R | R | R | R/W     | R/W     | R/W     | R/W     |

**Caution** 1. Rewrite bits TAAnOLm and TAAnOEm when TAAnCTL0.TAAnCE = 0 (the same value can be written when TAAnCE = 1.). If rewriting was mistakenly performed, clear TAAnCE to 0 and then set the bits again.

2. To enable the timer output, be sure to set the corresponding alternatefunction pins TAAnIOC1.TAAnIS[3:0] to "No edge detection" and invalidate the capture operation. Then set the corresponding alternate-function port to output mode.

#### Table 16-7 TAAnIOC0 register contents

| Bit<br>position | Bit name           | Function                                                                                                                                                                                                                                            |
|-----------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3, 1            | TAAnOL1<br>TAAnOL0 | <ul> <li>Specifies the TOAAnm output level.</li> <li>0: Normal output (inactive level = L, active level = H)</li> <li>1: Inverted output (inactive level = H, active level = L)</li> <li>This bit can be used to invert the timer output</li> </ul> |
| 2, 0            | TAAnOE1<br>TAAnOE0 | Controls the TOAAnm output.<br>0: Timer output is disabled (inactive level is output depending on the TAAnOLm bit)<br>1: Timer output is enabled (TOAAnm pin outputs pulses.)                                                                       |

Note m = 0, 1



#### (4) TAAnIOC1 - TAA dedicated I/O control register 1

The TAAnIOC1 register is an 8-bit register that controls the valid edge for the external input signals (TIAAn0 and TIAAn1).

Access This register can be read/written in 8-bit or 1-bit units.

| Address | TAA0IOC1: | FFFF603 <sub>H</sub> | TAA1IOC1: | FFFFF613 <sub>H</sub> |
|---------|-----------|----------------------|-----------|-----------------------|
|         | TAA2IOC1: | FFFF623 <sub>H</sub> | TAA3IOC1: | FFFFF633 <sub>H</sub> |
|         | TAA4IOC1: | FFFF643 <sub>H</sub> | TAA5IOC1: | FFFFF653 <sub>H</sub> |
|         | TAA6IOC1: | FFFF663 <sub>H</sub> | TAA7IOC1: | FFFFF673 <sub>H</sub> |
|         | TAA8IOC1: | FFFF683 <sub>H</sub> | TAA9IOC1: | FFFFF6B3 <sub>H</sub> |

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|          | 7 | 6 | 5 | 4 | 3       | 2       | 1       | 0       |
|----------|---|---|---|---|---------|---------|---------|---------|
| TAAnIOC1 | 0 | 0 | 0 | 0 | TAAnIS3 | TAAnIS2 | TAAnIS1 | TAAnIS0 |
|          | R | R | R | R | R/W     | R/W     | R/W     | R/W     |

**Caution** 1. Rewrite bits TAAnIS[3:0] when TAAnCTL0.TAAnCE = 0 (the same value can be written when TAAnCE = 1.). If rewriting was mistakenly performed, clear TAAnCE to 0 and then set the bits again.

- 2. Bits TAAnIS[3:0] are valid only in the free-running capture mode and pulse width measurement mode. In all the other modes, capture operation is not performed.
- 3. If used as the capture input, be sure to set the corresponding alternatefunction pins TAAnOE1 and TAAnOE0 of the TAAnIOC0 register to "Timer output is disabled" and set the capture input valid edge. Then set the corresponding alternate-function port to input mode.

| Table 16-8 | TAAnIOC1 | register contents |
|------------|----------|-------------------|
|------------|----------|-------------------|

| Bit<br>position | Bit name           | Function                 |                                                                           |                                                            |  |  |  |  |  |
|-----------------|--------------------|--------------------------|---------------------------------------------------------------------------|------------------------------------------------------------|--|--|--|--|--|
| 3, 2            | TAAIS3<br>TAAnIS2  | Specifies th             | Specifies the capture input (TIAAn1) valid edge.                          |                                                            |  |  |  |  |  |
|                 |                    | TAAnIS3                  | TAAnIS3         TAAnIS2         Capture input (TIAAn1) valid edge setting |                                                            |  |  |  |  |  |
|                 |                    | 0                        | 0                                                                         | No edge detection (capture operation invalid)              |  |  |  |  |  |
|                 |                    | 0                        | 1                                                                         | Rising edge detection                                      |  |  |  |  |  |
|                 |                    | 1                        | 0                                                                         | Falling edge detection                                     |  |  |  |  |  |
|                 |                    | 1                        | 1                                                                         | Both, rising and falling edge detection                    |  |  |  |  |  |
|                 |                    | Capture op<br>edge detec | •                                                                         | erformed and capture interrupt (INTTAAnCC1) is output upon |  |  |  |  |  |
| 1, 0            | TAAnIS1<br>TAAnIS0 | Specifies th             | ie capture ii                                                             | nput (TIAAn0) valid edge.                                  |  |  |  |  |  |
|                 |                    | TAAnIS1                  | TAAnIS0                                                                   | Capture input (TIAAn0) valid edge setting                  |  |  |  |  |  |
|                 |                    | 0                        | 0                                                                         | No edge detection (capture operation invalid)              |  |  |  |  |  |
|                 |                    | 0                        | 1                                                                         | Rising edge detection                                      |  |  |  |  |  |
|                 |                    | 1                        | 0                                                                         | Falling edge detection                                     |  |  |  |  |  |
|                 |                    | 1                        | 1                                                                         | Both, rising and falling edge detection                    |  |  |  |  |  |
|                 |                    | Capture op<br>edge detec | -                                                                         | erformed and capture interrupt (INTTAAnCC0) is output upon |  |  |  |  |  |



Α

#### (5) TAAnIOC2 - TAA I/O control register 2

The TAAnIOC2 register is an 8-bit register that controls the valid edge for external event count input signals (TEVTAAn) and external trigger input signal (TTRGAAn).

Access This register can be read/written in 8-bit or 1-bit units.

| ddroce  | TAA0IOC2: |                       | TAAUOCO   |                       |
|---------|-----------|-----------------------|-----------|-----------------------|
| luuress | TAAUIOCZ. | ггггоо4 <sub>Н</sub>  | TAATIOUZ. | FFFFF614 <sub>H</sub> |
|         | TAA2IOC2: | FFFFF624 <sub>H</sub> | TAA3IOC2: | FFFFF634 <sub>H</sub> |
|         | TAA4IOC2: | FFFFF644 <sub>H</sub> | TAA5IOC2: | FFFFF654 <sub>H</sub> |
|         | TAA6IOC2: | FFFF664 <sub>H</sub>  | TAA7IOC2: | FFFFF674 <sub>H</sub> |
|         | TAA8IOC2: | FFFF684 <sub>H</sub>  | TAA9IOC2: | FFFF6B4 <sub>H</sub>  |
|         |           |                       |           |                       |

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|          | 7 | 6 | 5 | 4 | 3        | 2        | 1        | 0        |
|----------|---|---|---|---|----------|----------|----------|----------|
| TAAnIOC2 | 0 | 0 | 0 | 0 | TAAnEES1 | TAAnEES0 | TAAnETS1 | TAAnETS0 |
|          | R | R | R | R | R/W      | R/W      | R/W      | R/W      |

**Caution** Rewrite TAAnEES[1:0] and TAAnETS[1:0] bits when TAAnCTL0.TAAnCE = 0 (the same value can be written when TAAnCE = 1). If rewriting was mistakenly performed, clear TAAnCE to 0 and then set the bits again.

#### Table 16-9 TAAnIOC2 register contents

| Bit<br>position | Bit name             |              | Function                                                         |                                                                                                                  |  |  |  |  |  |
|-----------------|----------------------|--------------|------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 3, 2            | TAAnEES1<br>TAAnEES0 | Specifies th | Specifies the external event counter input (TEVTAAn) valid edge. |                                                                                                                  |  |  |  |  |  |
|                 |                      | TAAnEES1     | TAAnEES0                                                         | External event counter input (TEVTAAn) valid edge setting                                                        |  |  |  |  |  |
|                 |                      | 0            | 0                                                                | No edge detection (capture operation invalid)                                                                    |  |  |  |  |  |
|                 |                      | 0            | 1                                                                | Rising edge detection                                                                                            |  |  |  |  |  |
|                 |                      | 1            | 0                                                                | Falling edge detection                                                                                           |  |  |  |  |  |
|                 |                      | 1            | 1                                                                | Both, rising and falling edge detection                                                                          |  |  |  |  |  |
|                 |                      |              |                                                                  | bits are valid only when TAAnEEE = 1 or when the external ode has been set (TAAnCTL1.TAAnMD[2:0] = 001B).        |  |  |  |  |  |
| 1, 0            | TAAnETS1<br>TAAnETS0 | Specifies th | ie external i                                                    | trigger input (TTRGAAn) valid edge.                                                                              |  |  |  |  |  |
|                 |                      | TAAnETS1     | TAAnETS0                                                         | External trigger input (TTRGAAn) valid edge setting                                                              |  |  |  |  |  |
|                 |                      | 0            | 0                                                                | No edge detection (capture operation invalid)                                                                    |  |  |  |  |  |
|                 |                      | 0            | 1                                                                | Rising edge detection                                                                                            |  |  |  |  |  |
|                 |                      | 1            | 0                                                                | Falling edge detection                                                                                           |  |  |  |  |  |
|                 |                      | 1            | 1                                                                | Both, rising and falling edge detection                                                                          |  |  |  |  |  |
|                 |                      |              |                                                                  | bits are only valid when the external trigger pulse output mode<br>lse mode is set (TAAnMD[2:0] = 010B or 011B). |  |  |  |  |  |

Note n = 0 to 9



#### (6) TAAnIOC4 - TAA I/O control register 4

The TAAnIOC4 register is an 8-bit register that controls the output function of Timer AA.

Access This register can be read/written in 8-bit or 1-bit units.

| Address | TAA0IOC4: | FFFF60C <sub>H</sub> | TAA1IOC4  | FFFF61C <sub>H</sub>  |
|---------|-----------|----------------------|-----------|-----------------------|
|         | TAA2IOC4: | FFFF62C <sub>H</sub> | TAA3IOC4: | FFFFF63C <sub>H</sub> |
|         | TAA4IOC4: | FFFF64C <sub>H</sub> | TAA5IOC4: | FFFF65C <sub>H</sub>  |
|         | TAA6IOC4: | FFFF66C <sub>H</sub> | TAA7IOC4: | FFFF67C <sub>H</sub>  |
|         | TAA8IOC4: | FFFF68C <sub>H</sub> | TAA9IOC4: | FFFF6BC <sub>H</sub>  |

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|          | 7 | 6 | 5 | 4 | 3       | 2       | 1       | 0       |
|----------|---|---|---|---|---------|---------|---------|---------|
| TAAnIOC4 | 0 | 0 | 0 | 0 | TAAnOS1 | TAAnOR1 | TAAnOS0 | TAAnOR0 |
|          | R | R | R | R | R/W     | R/W     | R/W     | R/W     |

**Caution** The TAAnIOC4 register can only be used when interval mode or free-running compare mode is selected. In all other modes the TAAnIOC4 register has to be set to 00<sub>H</sub>.

#### Table 16-10 TAAnIOC4 register contents

| Bit<br>position | Bit name           |              | Function                                                                                                                                                                                                                               |                                                                                                                                                                     |  |  |  |  |
|-----------------|--------------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 3, 2            | TAAnOS1<br>TAAnOR1 | Controls tog | gling of the                                                                                                                                                                                                                           | timer output TOAAn1.                                                                                                                                                |  |  |  |  |
|                 |                    | TAAnOS1      | TAAnOR1                                                                                                                                                                                                                                | Toggle Control of TOAAn1                                                                                                                                            |  |  |  |  |
|                 |                    | 0            | 0                                                                                                                                                                                                                                      | Standard operation.                                                                                                                                                 |  |  |  |  |
|                 |                    | 0            | 1                                                                                                                                                                                                                                      | Force output level to inactive at next toggle event                                                                                                                 |  |  |  |  |
|                 |                    | 1            | 0                                                                                                                                                                                                                                      | Force output level to active at next toggle event                                                                                                                   |  |  |  |  |
|                 |                    | 1            | 1                                                                                                                                                                                                                                      | Freeze current output level.                                                                                                                                        |  |  |  |  |
|                 |                    | 2.           | the output level to either active or inactive, the TOAAn1<br>tains this level (= no toggling afterwards) until the TAAnOS1<br>R1 are cleared to standard operation.<br>of an output level is executed at the time of the next upcoming |                                                                                                                                                                     |  |  |  |  |
|                 |                    | 1            | toggle event                                                                                                                                                                                                                           | t, while the freeze becomes effective immediately.                                                                                                                  |  |  |  |  |
| 1, 0            | TAAnOS0<br>TAAnOR0 | Controls tog | ggling of the                                                                                                                                                                                                                          | timer output TOAAn0.                                                                                                                                                |  |  |  |  |
|                 |                    | TAAnOS0      | TAAnOR0                                                                                                                                                                                                                                | Toggle Control of TOAAn0                                                                                                                                            |  |  |  |  |
|                 |                    | 0            | 0                                                                                                                                                                                                                                      | Standard operation.                                                                                                                                                 |  |  |  |  |
|                 |                    | 0            | 1                                                                                                                                                                                                                                      | Force output level to inactive at next toggle event                                                                                                                 |  |  |  |  |
|                 |                    | 1            | 0                                                                                                                                                                                                                                      | Force output level to active at next toggle event                                                                                                                   |  |  |  |  |
|                 |                    | 1            | 1                                                                                                                                                                                                                                      | Freeze current output level.                                                                                                                                        |  |  |  |  |
|                 |                    |              | output main                                                                                                                                                                                                                            | the output level to either active or inactive, the TOAAn0<br>tains this level (= no toggling afterwards) until the TAAnOS0<br>R0 are cleared to standard operation. |  |  |  |  |
|                 |                    |              |                                                                                                                                                                                                                                        | of an output level is executed at the time of the next upcoming<br>t, while the freeze becomes effective immediately.                                               |  |  |  |  |



#### (7) TAAnOPT0 - TAA option register 0

The TAAnOPT0 register is an 8-bit register used to set the capture/compare operation and detect overflow.

Access This register can be read/written in 8-bit or 1-bit units.

Address

| 615 <sub>H</sub> |
|------------------|
| 635 <sub>H</sub> |
| 655 <sub>H</sub> |
| 675 <sub>H</sub> |
| B5 <sub>H</sub>  |
|                  |

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|          | 7   | 6   | 5        | 4        | 3   | 2   | 1   | 0       |
|----------|-----|-----|----------|----------|-----|-----|-----|---------|
| TAAnOPT0 | 0   | 0   | TAAnCCS1 | TAAnCCS0 | 0   | 0   | 0   | TAAnOVF |
|          | R/W | R/W | R/W      | R/W      | R/W | R/W | R/W | R/W     |

**Caution** Rewrite TAAnCCS1 and TAAnCCS0 bits when TAAnCTL0.TAAnCE = 0 (the same value can be written when TAAnCE = 1.). If rewriting was mistakenly performed, clear TAAnCE to 0 and then set the bits again.

#### Table 16-11 TAAnOPT0 register contents

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |
|-----------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 5               | TAAnCCS1 | Specifies the operation mode of register TAAnCCR1<br>0: Operation as compare register<br>1: Operation as capture register<br><b>Note:</b> The setting of bit TAAnCCS1 is valid in the free-running mode only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
| 4               | TAAnCCS0 | Specifies the operation mode of register TAAnCCR0<br>0: Operation as compare register<br>1: Operation as capture register<br>Note: The setting of bit TAAnCCS0 is valid in the free-running mode only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |
| 0               | TAAnOVF  | <ul> <li>Indicates timer TAAn overflow <ul> <li>No overflow occurrence after timer restart or flag reset</li> <li>Overflow occurrence</li> </ul> </li> <li>The TAAnOVF bit is set when the 16-bit counter value overflows from FFFFH to 0000H in the free-running mode and the pulse width measurement mode.</li> <li>An interrupt request signal (INTTAAnOV) is generated as soon as TAAnOVF bit is set (1). <ul> <li>The INTTAAnOV signal is not generated in any mode other than free-running mode and the pulse width measurement mode.</li> </ul> </li> <li>The TAAnOVF bit is cleared by writing 0 to it, or if TAAnCTL0.TAAnCE is set to 0.</li> </ul> <b>Caution:</b> 1. When TAAnOVF = 1, the TAAnOVF flag is not cleared even if the TAAnOVF flag and TAAnOPT0 register are read. 2. The TAAnOVF flag can be read and written, but even if 1 is written to the TAAnOVF flag from the CPU, this is ignored and has no influence on the timer operation. |  |  |  |  |  |  |  |



#### (8) TAAnOPT1 - TAA option register 1

The TAAnOPT1 register is an 8-bit register used to set the 32-bit capture mode by cascading two Timer AA.

- Access This register can be read/written in 8-bit or 1-bit units.
- AddressTAA1OPT1: FFFF61D\_HTAA2OPT1=FFFF62D\_HTAA3OPT1: FFFF63D\_HTAA5OPT1=FFFF65D\_HTAA6OPT1: FFFF66D\_HTAA7OPT1=FFFF67D\_HTAA9OPT1: FFFF66D\_HTAA7OPT1=FFFF67D\_H

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|          | 7       | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----------|---------|-----|-----|-----|-----|-----|-----|-----|
| TAAnOPT1 | TAAnCSE | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
|          | R/W     | R/W | R/W | R/W | R/W | R/W | R/W | R/W |

#### Table 16-12 TAAnOPT0 register contents

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
|-----------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7               | TAAnCSE  | <ul> <li>Controls the cascade mode of timers TAAn/TAAm.</li> <li>0: 16-bit non-cascaded mode</li> <li>1: 32-bit cascaded capture mode.<br/>Timer AAn becomes the upper 16-bit and slave. The master timer is TAAm (where m = 0, when n = 1 to 3; m = 4, when n = 5 to 7; m = 8, when n = 9).</li> <li>Note: 1. When setting TAAnCSE, the timer becomes the upper 16-bit of a 32-bit timer.</li> <li>2. Cascading is only available for capture with free-running counter.</li> <li>3. The following pairs of timers can be cascaded: <ul> <li>TAA0 and one of TAA1 to TAA3<br/>(TAA0 will become master and will hold the lower 16-bit value)</li> <li>TAA4 and one of TAA5 to TAA7<br/>(TAA4 will become master and will hold the lower 16-bit value)</li> <li>TAA8 and TAA9<br/>(TAA8 will become master and will hold the lower 16-bit value)</li> </ul> </li> </ul> |  |  |  |  |  |

The table below shows the effects of the TAAnCSE flag on the timer operation:

#### Table 16-13 Timer Operation in Non-cascaded/Cascaded Capture Mode

|                   | TAAnCSE=0                                                | TAAnCSE=1                                 |
|-------------------|----------------------------------------------------------|-------------------------------------------|
| Operating clock   | macro clock from clock tree                              | macro clock of TAAm                       |
| Count Enable      | TAAnCE bit of TAAnCTL0                                   | TAAmCE bit of TAAm                        |
| Count Clock       | selected by TAAnCKS[2:0]                                 | Counter overflow from TAAm                |
| Capture Signal 0  | TIAAn0 input with edge filter as selected by TAAnIS[1:0] | TIAAm0 with edge filter selected for TAAm |
| Capture Signal 1  | TIAAn1 input with edge filter as selected by TAAnIS[3:2] | TIAAm1 with edge filter selected for TAAm |
| Capture Interrupt | INTTAAnCC0 or INTTAAnCC1                                 | INTTAAmCC0 or INTTAAmCC1                  |

n=1 or 3; m= (n-1).

For details on the 32-bit capture mode, refer to *"32-bit Capture in free-running cascade mode" on page 600*.



#### Chapter 16

### (9) TAAnSVC - TAA specific overflow value control register

The TAAnSVC controls the setting of defined overflow values OVFV to the TAAn capture/compare registers in case of overflows.

Access This register can be read/written in 8-bit or 1-bit units.

| Address | TAA0SVC: | FFFFF60E <sub>H</sub>  | TAA1SVC: | FFFFF61E <sub>H</sub> |
|---------|----------|------------------------|----------|-----------------------|
|         | TAA2SVC: | FFFFF62E <sub>H</sub>  | TAA3SVC: | FFFFF63E <sub>H</sub> |
|         | TAA4SVC: | FFFFF64E <sub>H</sub>  | TAA5SVC: | FFFFF65E <sub>H</sub> |
|         | TAA6SVC: | FFFFF66EH <sub>H</sub> | TAA7SVC: | FFFFF67E <sub>H</sub> |
|         | TAA8SVC: | FFFFF68E <sub>H</sub>  | TAA9SVC: | FFFFF6BE <sub>H</sub> |

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|         | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
|---------|----------|----------|----------|----------|----------|----------|----------|----------|
| TAAnSVC | TAAnENC1 | TAAnCSE1 | TAAnCSD1 | TAAnCSR1 | TAAnENC0 | TAAnCSE0 | TAAnCSD0 | TAAnCSR0 |
|         | R/W      |
|         |          |          |          |          |          |          |          |          |

**Caution 1.** Write to the TAAnSVC register is only permitted, when TAAnCTL0.TAAnCE = 0.

**2.** The capture inputs TIAn0 and TIAn1 of TAAn must be connected externally, so that both inputs get the same signal.

#### Table 16-14 TAAnSVC register contents (1/2)

| Bit<br>position | Bit name             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7, 3            | TAAnENC1<br>TAAnENC0 | <ul> <li>Controls setting of TAAnCCRm register overflow value.</li> <li>0: Overflow value writing disabled.</li> <li>1: Overflow value writing enabled.</li> <li>TAAnCCRm is overwritten upon INTAAnOV generation.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 6, 2            | TAAnCSE1<br>TAAnCSE0 | <ul> <li>Specifies the TIAnm overflow value (OVFV).</li> <li>0: If TIAnm = L (0) during overflow: overflow value OVFV = 0xFFFF<br/>If TIAnm = H (1) during overflow: overflow value OVFV = 0x0000</li> <li>1: If TIAnm = H (1) during overflow: overflow value OVFV = 0xFFFF<br/>If TIAnm = L (0) during overflow: overflow value OVFV = 0x0000</li> <li>TAAnCSEm determines also the selection of the valid capture input trigger edge of<br/>the input signals TIAAnm in combination with TAAnIOC1.TAAnIS[3:2] and<br/>TAAnIOC1.TAAnIS[1:0] respectively.</li> <li>Upon an overflow event a comparsion is made between the level of TIAnm input<br/>signal and the TAAnCSEMm bit.</li> <li>The result of the comparison determines the overflow value:</li> <li>if TIAnm = TAAnCSEm: overflow value OVFV = 0x0000 (no match)</li> <li>The overflow value finally set to the TAAnCCRm register depends also on<br/>TAAnCSDm and TAAnCSRm.</li> </ul> |



| Table 16-14 | TAAnSVC register contents (2 | 2/2) |
|-------------|------------------------------|------|
|-------------|------------------------------|------|

| Bit<br>position | Bit name             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5, 1            | TAAnCSD1<br>TAAnCSD0 | <ul> <li>Specified the TAAnCCRm overwrite operation.</li> <li>0: Overflow value is written to TAAnCCRm in case of an overflow event, independent of TIAnm level and TAAnCSEn.</li> <li>1: Overflow value, written to TAAnCCRm in case of an overflow event, depends on level of TIAnm and TAAnCSEn: <ul> <li>if TIAnm = TAAnCSEm: overflow value OVFV set to TAAnCCRm</li> <li>if TIAnm = not(TAAnCSEm): TAAnCCRm remains unchanged</li> </ul> </li> <li>By use of the TAAnCSDm bit, overwriting of TAAnCCRm by an overflow value OVFV can be prohibited, if TIAnm = not(TAAnCSEm).</li> </ul> |
| 4, 0            | TAAnCSR1<br>TAAnCSR0 | Overflow value OVFV inversion control<br>0: Overflow value OVFV is not inverted.<br>1: Overflow value OVFV is inverted.<br>By use of the TAAnCSRm bit, the overflow value OVFV written to TAAnCCRm can be<br>inverted.                                                                                                                                                                                                                                                                                                                                                                         |

Overwriting of the TAAnCCRm register coincide with the generation of the overflow interrupt INTTAAnCCm and setting of the overflow flag TAAnOPT0.TAAnOVF.

The following table summarizes the values written to the TAAnCCRm register under the various control settings of TAAnSVC, in case the overflow setting function is enabled for capture/compare channel m by TAAnSVC.TAAnENCm = 1.

Valid edge specification The valid edges of the capture trigger inputs TIAAnm are determined by TAAnSVC.TAAnCSE0 and TAAnIOC1.TAAnIS[3:2], respectively TAAnIOC1.TAAnIS[1:0]. These bits must be set according to *Table 16-15*.

| TAAnCSE0 | TAAnCSD0 | TAAnCSR0 | TIAn0 | TAAnIS1 | TAAnIS0 | TAAnCCR0            | Remark              |
|----------|----------|----------|-------|---------|---------|---------------------|---------------------|
| TAAnCSE1 | TAAnCSD1 | TAAnCSR1 | TIAn1 | TAAnIS3 | TAAnIS2 | TAAnCCR1            | Tiemark             |
|          |          | 0        | L     | х       | 1       | 0xFFFF              | TIAnm =<br>TAAnCSEm |
|          | 0        | 0        | Н     | х       | 1       | 0x0000              | TIAnm =<br>TAAnCSEm |
|          |          | 1        | L     | Х       | 1       | 0x0000              | reverse             |
| 0        |          |          | Н     | Х       | 1       | 0xFFFF              | of above            |
|          | 0        | L        | х     | 1       | 0xFFFF  | TIAnm =<br>TAAnCSEm |                     |
|          | 1        | -        | Н     | х       | 1       | no change           | <u> </u>            |
|          |          | 1        | L     | Х       | 1       | no change           | reverse             |
|          |          |          | Н     | Х       | 1       | 0xFFFF              | of above            |

|  | Table 16-15 | Overflow value setting conditions | (1/2) |
|--|-------------|-----------------------------------|-------|
|--|-------------|-----------------------------------|-------|



| TAAnCSE0 | TAAnCSD0 | TAAnCSR0 | TIAn0 | TAAnIS1 | TAAnIS0 | TAAnCCR0 | Remark              |                     |
|----------|----------|----------|-------|---------|---------|----------|---------------------|---------------------|
| TAAnCSE1 | TAAnCSD1 | TAAnCSR1 | TIAn1 | TAAnIS3 | TAAnIS2 | TAAnCCR1 | nemark              |                     |
| 1        |          | 0        | L     | 1       | х       | 0x0000   | TIAnm =<br>TAAnCSEm |                     |
|          | 0        | 0        | Н     | 1       | х       | 0xFFFF   | TIAnm =<br>TAAnCSEm |                     |
|          |          | 1        | L     | 1       | Х       | 0xFFFF   | reverse             |                     |
|          |          |          | Н     | 1       | Х       | 0x0000   | of above            |                     |
|          | 1        | 1        | 0     | L       | 1       | х        | no change           | TIAnm =<br>TAAnCSEm |
|          |          |          |       | Н       | 1       | х        | 0xFFFF              | TIAnm =<br>TAAnCSEm |
|          |          | 1        | L     | 1       | Х       | 0xFFFF   | reverse             |                     |
|          |          | 1        | Ι     | Н       | 1       | Х        | no change           | of above            |

 Table 16-15
 Overflow value setting conditions (2/2)

The following flowchart illustrates how the final content of the TAAnCCRm is evaluated.



Figure 16-6 Evaluation of overflow value OVFV

For further information concerning the overflow value function refer to *"Specific TAAnCCRm overflow value write"* on page 605.



## 16.6 Operation

| Operation                                          | TAAnEST<br>Software<br>trigger bit | TIAAn0<br>External<br>trigger input | TAAnEEE<br>Count clock<br>selection | Capture/Compar<br>e<br>Selection | Compare<br>Write |
|----------------------------------------------------|------------------------------------|-------------------------------------|-------------------------------------|----------------------------------|------------------|
| Interval timer mode                                | Invalid                            | Invalid                             | Internal/TIAAn0<br>pin              | Compare only                     | Any time write   |
| External event counter mode                        | Invalid                            | Invalid                             | External only                       | Compare only                     | Any time write   |
| External trigger pulse output mode <sup>Note</sup> | Valid                              | Valid                               | Internal only                       | Compare only                     | Reload           |
| One-shot pulse output mode <sup>Note</sup>         | Valid                              | Valid                               | Internal only                       | Compare only                     | Any time write   |
| PWM mode                                           | Invalid                            | Invalid                             | Internal/TIAAn0<br>pin              | Compare only                     | Reload           |
| Free-running mode                                  | Invalid                            | Invalid                             | Internal/TIAAn0<br>pin              | Capture/compare selectable       | Any time write   |
| Pulse width<br>measurement mode <sup>Note</sup>    | Invalid                            | Invalid                             | Internal only                       | Capture only                     | Not applicable   |

Timer AA can perform the following operations when not in cascade mode:

**Note** To use the external trigger pulse output mode, one-shot pulse mode, or pulse width measurement mode, select a count clock by clearing the TAAnEEE bit of the TAAnCTL1 register to 0.



### 16.6.1 Anytime write and reload

TAAnCCR0 and TAAnCCR1 register rewrite is possible for timer AA during timer operation (TAAnCE = 1), but the write method (any time write, reload) differs depending on the mode.

#### (1) Anytime write

When data is written to the TAAnCCRm register during timer operation, it is transferred at any time to CCRm buffer register and used as the 16-bit counter comparison value.





- **Note 1.** The above flowchart illustrates an example of the operation in the interval timer mode.
  - **2.** n = 0 to 9; m = 0, 1





Figure 16-8 Timing diagram for anytime write

D01, D02: Setting values of TAAnCCR0 register (0000H to FFFH) D11, D12: Setting values of TAAnCCR1 register (0000H to FFFFH)

The above timing chart illustrates an example of the operation in the interval timer mode.



## (2) Reload

When data is written to the TAAnCCR0 and TAAnCCR1 registers during timer operation, it is compared with the value of the 16-bit counter via the CCRm buffer register. The values of the TAAnCCR0 and TAAnCCR1 registers can be rewritten when TAAnCE = 1.

So that the set values of the TAAnCCR0 and TAAnCCR1 registers are compared with the value of the 16-bit counter (the set values are reloaded to the CCRm buffer register), the value of the TAAnCCR0 register must be rewritten and then a value must be written to the TAAnCCR1 register before the value of the 16-bit counter matches the value of TAAnCCR0. When the value of the TAAnCCR0 register matches the value of the 16-bit counter, the values of the TAAnCCR0 and TAAnCCR1 registers are reloaded.

Whether the next reload timing is made valid or not is controlled by writing to the TAAnCCR1 register. Therefore, write the same value to the TAAnCCR1 register when it is necessary to rewrite the value of only the TAAnCCR0 register.



Figure 16-9 Flowchart of basic operation for reload

**Caution** Writing to the TAAnCCR1 register includes an operation to enable reload. Therefore, rewrite the TAAnCCR1 register after rewriting the TAAnCCR0 register.

- Note 1. Above flowchart illustrates an example of the PWM mode operation.
  - **2.** n = 0 to 9; m = 0, 1







Note Reload is not performed because TAAnCCR1 register is not written.

D01, D02, D03: Setting value of TAAnCCR0 register (0000H to FFFH) D11, D12: Setting value of TAAnCCR1 register (0000H to FFFFH)

Above flowchart illustrates PWM mode operation.



## 16.6.2 Interval timer mode (TAAnMD2 to TAAnMD0 = $000_B$ )

In the interval timer mode, an interrupt request signal (INTTAAnCC0) is generated upon a match between the setting value of the TAAnCCR0 register and the value of the 16-bit counter, and the 16-bit counter is cleared. The TAAnCCR0 register can be rewritten when TAAnCE = 1, and when a value is set to TAAnCCR0 with a write instruction from the CPU, it is transferred to the CCR0 buffer register through any time write mode, and is compared with the 16-bit counter value.

In the interval timer mode, the 16-bit counter is cleared only upon a match between the value of the 16-bit counter and the value of the CCR0 buffer register.

16-bit counter clearing using the TAAnCCR1 register is not performed. However, the setting value of the TAAnCCR1 register is transferred to the CCR1 buffer register and compared with the value of the 16-bit counter, and an interrupt request (INTTAAnCC1) is output if these values match. In addition, TOAA1n pin output is also possible by setting the TAAnOE1 bit to 1.

When the TAAnCCR1 register is not used, it is recommended to set FFFH as the setting value for the TAAnCCR1 register.

When performing timer output with the TOAAn1 pin, set the same values to the TAAnCCR0 register and the TAAnCCR1 register since the 16-bit timer counter cannot be cleared with the TAAnCCR1 register.



Figure 16-11 Flowchart of basic operation in interval timer mode

**Note** The 16-bit counter is not cleared when its value matches the value of TAAnCCR1.





Figure 16-12 Basic operation timing in interval timer mode When D1 > D2 > D3; only TAAnCCR0 register value is written, and TOAAn0 and TOAAn1 are not output (TAAnOE0 = 0, TAAnOE1 = 0, TAAnOL0 = 0, TAAnOL1 = 1)

Note The 16-bit counter is not cleared when its value matches the value of TAAnCCR1.

D1, D2: Setting values of TAAnCCR0 register (0000H to FFFFH) D3: Setting value of TAAnCCR1 register (0000H to FFFFH)

Interval time  $(t_{Dn})=(Dn + 1) \times (count clock cycle)$ 

RENESAS



Figure 16-13 Basic operation timing in interval timer mode When D1 = D2; TAAnCCR0 and TAAnCCR1 are not rewritten, and TOAAn0 and TOAAn1 are output (TAAnOE0 = 1, TAAnOE1 = 1, TAAnOL0 = 0, TAAnOL1 = 1)

> D1: Setting value of TAAnCCR0 register (0000H to FFFFH) D2: Setting value of TAAnCCR1 register (0000H to FFFFH)

Interval time  $(t_{Dn}) = (Dn + 1) \times (count clock cycle)$ 

RENESAS

### 16.6.3 External event counter mode (TAAnMD2 to TAAnMD0 = $001_B$ )

In the external event count mode, the external event count input (TEVTAAn pin input) is used as a count-up signal. Regardless of the setting of the TAAnEEE bit of the TAAnCTL0 register, 16-bit timer/event counter AA counts up the external event count input (TEVTAAn pin input) when it is set in the external event count mode. In the external event count mode, an interrupt request (INTTAAnCC0) is generated when the set value of the TAAnCCR0 register matches the value of the 16-bit counter, and the value of the 16-bit counter is cleared.

When a value is set to the TAAnCCR0 register with a write instruction from the CPU, it is transferred to the CCR0 buffer register through any time write, and is compared with the 16-bit counter value.

In the external event counter mode, the 16-bit counter is cleared only upon a match between the value of the 16-bit counter and the value of the CCR0 buffer register.

The 16-bit counter can not be cleared using TAAnCCR1 register. However, the setting value of the TAAnCCR1 register is transferred to the CCR1 buffer register and compared with the value of the 16-bit counter, and an interrupt request (INTTAAnCC1) is output if these values match.

Moreover, TOAAnm pin output is also possible by setting the TAAnOEm bit to 1.

When performing timer output with the TOAAn1 pin, set the same values to TAAnCCR0 register and TAAnCCR1 register since the 16-bit counter cannot be cleared with CCR1 buffer register.

The TAAnCCR0 register can be rewritten when TAAnCE = 1. When TAAnCCR1 register is not used, it is recommended to set TAAnCCR1 register to FFFFH.





- Figure 16-14 Flowchart of basic operation in external event counter mode
  - Note 1. Selection of the TAAnEEE bit has no influence.
    - 2. The 16-bit counter is not cleared upon a match between the 16-bit counter and the CCR1 buffer register.
    - 3. n = 0 to 9; m = 0, 1





#### Figure 16-15 Basic operation timing in external event counter mode When D1 > D2 > D3; rewrite TAAnCCR0 only; TOAAn1 is not output (TAAnOE0 = 0, TAAnOE1 = 0, TAAnOL0 = 0, TAAnOL1 = 1)

D1, D2: Setting values of TAAnCCR0 register (0000H to FFFFH) D3: Setting value of TAAnCCR1 register (0000H to FFFFH)

Number of event counts = (Dn + 1)





- Figure 16-16 Basic operation timing in external event counter mode When D1 = D2; TAAnCCR0 and TAAnCCR1 are not rewritten, TOAAn1 is output (TAAnOE0 = 1, TAAnOE1 = 1, TAAnOL0 = 0, TAAnOL1 = 1)
  - D1: Setting value of TAAnCCR0 register (0000H to FFFFH) D2: Setting value of TAAnCCR1 register (0000H to FFFFH)

Number of event count = (Dn + 1)



### 16.6.4 External trigger pulse mode (TAAnMD2 to TAAnMD0 = $010_B$ )

When TAAnCE = 1 in the external trigger pulse mode, the 16-bit counter stops at FFFFH and waits for input of an external trigger (TTRGAAn pin input). When the counter detects the edge of the external trigger (TTRGAAn pin input), it starts counting up. The duty factor of the signal output from the TOAAn1 pin is set by a reload register (TAAnCCR1) and the period is set by a compare register (TAAnCCR0).

Rewriting the TAAnCCR0 and TAAnCCR1 registers is enabled when TAAnCE = 1.

To ensure that the selected values of the TAAnCCR0 and TAAnCCR1 registers after rewriting are compared with the value of the 16-bit counter (reloaded to the CCRm buffer register), the TAAnCCR0 register and then the TAAnCCR1 register must be written before the value of the 16-bit counter matches the value of the TAAnCCR0 register.

When the value of the TAAnCCR0 register later matches the value of the 16-bit counter, the values of the TAAnCCR0 and TAAnCCR1 registers are reloaded to the CCRm buffer register.

Whether the next reload timing is made valid or not is controlled by writing to the TAAnCCR1 register. Therefore, write the same value to the TAAnCCR1 register when it is necessary to rewrite the value of only the TAAnCCR0 register.

Reload is invalid when only the TAAnCCR0 register is rewritten. To stop timer AA, clear TAAnCE to 0. If the edge of the external trigger (TTRGAAn pin input) is detected more than once in the external trigger pulse mode, the 16-bit counter is cleared at the point of edge detection, and resumes counting up. To realize the same function as the external trigger pulse mode by using a software trigger instead of the external trigger input (TTRGAAn pin input) (software trigger pulse mode), a software trigger is generated by setting the TAAnEST bit of the TAAnCTL1 register to 1.

When using a software trigger, a square wave that has one cycle of the PWM waveform as half of its own cycle can also be outputed from the TOAAn0 pin.

The waveform of the external trigger pulse is output from TOAAn1. A toggle output is produced from the TOAAn0 pin when the value of the TAAnCCR0 register matches the value of the 16-bit counter.

In the external trigger pulse mode, the capture function of the TAAnCCR0 and TAAnCCR1 registers cannot be used because these registers can be used only as compare registers.

**Caution** In the external trigger pulse mode, select the internal clock (TAAnEEE bit of TAAnCTL1 register = 0) for the count clock.

- **Note** 1. For the reload operation when TAAnCCR0 and TAAnCCR1 are rewritten during timer operation, refer to *"PWM mode (TAAnMD2 to TAAnMD0 = 100<sub>B</sub>)" on page 582*.
  - 2. n = 0 to 9; m = 0, 1





- Figure 16-17 Flowchart of basic operation in external trigger pulse output mode
  - **Note 1.** The 16-bit counter is not cleared upon a match between the 16-bit counter and the CCR1 buffer register.





- Figure 16-18 Basic operation timing in external trigger pulse output mode (TAAnOE0 = 1, TAAnOE1 = 1, TAAnOL0 = 0, TAAnOL1 = 0)
  - Note The 16-bit counter is not cleared when it matches the CCR1 buffer register.

D01, D02: Setting value of TAAnCCR0 register (0000H to FFFFH) D11, D12: Setting value of TAAnCCR1 register (0000H to FFFFH)

Duty of TOAAn1 output = (Set value of TAAnCCR1 register) / (Set value of TAA0CCR0 register) Cycle of TOAAn1 output = (Set value of TAAnCCR0 register) Þ (Count clock cycle)



### 16.6.5 One-shot pulse mode (TAAnMD2 to TAAnMD0 = $011_B$ )

When TAAnCE is set to 1 in the one-shot pulse mode, the 16-bit counter waits for the setting of the TAAnEST bit (to 1) or a trigger that is input when the edge of the TTRGAAn pin is detected, while holding FFFFH. When the trigger is input, the 16-bit counter starts counting up.

When the value of the 16-bit counter matches the value of the CCR1 buffer register that has been transferred from the TAAnCCR1 register, TOAAn1 goes high. When the value of the 16-bit counter

matches the value of the CCR0 buffer register that has been transferred from the TAAnCCR0 register, TOAAn1 goes low, and the 16-bit counter is cleared to 0000H and stops. Input of a second or subsequent trigger is ignored while the 16-bit counter is operating. Be sure to input a second trigger while the 16-bit counter is stopped at 0000H. In the one shot pulse mode, rewriting the TAAnCCR0 and TAAnCCR1 registers is enabled when TAAnCE = 1. The set values of the TAAnCCR0 and TAAnCCR1 registers become valid after a write instruction from the CPU is executed. They are then transferred to the CCR0 and CCR1 buffer registers, and compared with the value of the 16-bit counter. The waveform of the one-shot pulse is output from the TOAAn1 pin. The TOAAn0 pin produces a toggle output when the value of the 16-bit counter matches the value of the TAAnCCR0 register. In the one-shot pulse mode, the TAAnCCR0 and TAAnCCR1 registers function only as compare registers. They cannot be used as capture registers.

- Caution 1. In the one-shot pulse mode, select the internal clock (TAAnEEE bit of TAAnCTL1 register = 0) as the count clock.
  - 2. In the one-shot pulse mode, it is prohibited to set the TAAnCCR1 register to 0000H.





### Figure 16-19 Flowchart of basic operation in one-shot pulse mode

- **Note 1.** The 16-bit counter is not cleared upon a match between the 16-bit counter and the CCR1 buffer register.
- **Caution** The 16-bit counter is not cleared when a trigger input is performed during the count-up operation of the 16-bit counter.





Figure 16-20 Timing of basic operation in one-shot pulse mode (TAAnOE0 = 1, TAAnOE1 = 1, TAAnOL0 = 0, TAAnOL1 = 0)

**Note** The 16-bit counter starts counting up when either TAAnEST = 1 is set or the external trigger (TTRGAAn) is input.

D0: Setting value of TAAnCCR0 register (0000H to FFFFH) D1: Setting value of TAAnCCR1 register (0000H to FFFFH)



### 16.6.6 PWM mode (TAAnMD2 to TAAnMD0 = $100_B$ )

In the PWM mode, TAAn capture/compare register 1 (TAAnCCR1) is used to set the duty factor and TAAn capture/compare register 0 (TAAnCCR0) is used to set the cycle. By using these two registers and operating the timer, variable-duty PWM is output.

Rewriting the TAAnCCR0 and TAAnCCR1 registers is enabled when TAAnCE = 1.

So that the set values of the TAAnCCR0 and TAAnCCR1 registers are compared with the value of the 16-bit counter (reloaded to the CCR0 and CCR1 buffer registers), the TAAnCCR0 register must be rewritten and then a value must be written to the TAAnCCR1 register before the value of the 16-bit counter matches the value of the TAAnCCR0 register.

The values of the TAAnCCR0 and TAAnCCR1 registers are reloaded when the value of the TAAnCCR0 register later matches the value of the 16-bit counter. Whether the next reload timing is made valid or not is controlled by writing to the TAAnCCR1 register. Therefore, write the same value to the TAAnCCR1 register even when only the value of the TAAnCCR0 register needs to be rewritten. Reload is invalid when only the value of the TAAnCCR0 register is rewritten.

To stop timer AA, clear TAAnCE to 0.

The waveform of PWM is output from the TOAAn1 pin. The TOAAn0 pin produces a toggle output when the 16-bit counter matches the TAAnCCR0 register.

In the PWM mode, the TAAnCCR0 and TAAnCCR1 registers are used only as compare registers. They cannot be used as capture registers.





Figure 16-21 Flowchart of basic operation in PWM mode When values of TAAnCCR0, TAAnCCR1 registers are not rewritten during timer operation





- Figure 16-22 Flowchart of basic operation in PWM mode When values of TAAnCCR0, TAAnCCR1 registers are rewritten during timer operation
  - Note 1. The timing of <2> in the above flowchart may differ depending on the rewrite timing of steps <1> and <3> and the value of TAAnCCR1, but make sure that step <3> comes after step <1>.
    - **2.** n = 0 to 9; m = 0, 1



Figure 16-23 Basic Operation Timing in PWM mode When rewriting TAAnCCR1 value (TAAnOE0 = 1, TAAnOE1 = 1, TAAnOL0 = 0, TAAnOL1 = 0)

> D00: Set value of TAAnCCR0 register (0000H to FFFFH) D10, D11, D12, D13: Set value of TAAnCCR1 register (0000H to FFFFH)

> Duty factor of TOAAn1 output = (Set value of TAAnCCR1 register) / (Set value of TAA0CCR0 register + 1) Cycle of TOAAn1 output = (Set value of TAAnCCR0 register + 1) x (Count clock cycle) Toggle width of TOAAn0 output = (Set value of TAAnCCR0 register + 1) x (Count clock cycle)





Figure 16-24 Basic operation timing in PWM mode When TAAnCCR0, TAAnCCR1 values are rewritten (TAAnOE0 = 1, TAAnOE1 = 1, TAAnOL0 = 0, TAAnOL1 = 0)

Note Reload is not performed because the TAAnCCR1 register was not rewritten.

D00, D01, D02, D03: Setting values of TAAnCCR0 register (0000H to FFFFH) D10, D11, D12, D13: Setting values of TAAnCCR1 register (0000H to FFFFH)

Duty factor of TOAAn1 output = (Set value of TAAnCCR1 register) / (Set value of TAA0CCR0 register + 1) Cycle of TOAAn1 output = (Set value of TAAnCCR0 register + 1) x (Count clock cycle) Toggle width of TOAAn0 output = (Set value of TAAnCCR0 register + 1) x (Count clock cycle)



### 16.6.7 Free-running mode (TAAnMD2 to TAAnMD0 = $101_B$ )

In the free-running mode, both the interval function and the compare function can be realized by operating the 16-bit counter as a free-running counter and selecting capture/compare operation with the TAAnCCS1 and TAAnCCS0 bits.

The settings of the TAAnCCS1 and TAAnCCS0 bits of the TAAnOPT0 register are valid only in the free-running mode.

| TAAnCCS1 | Operation                                 |  |  |
|----------|-------------------------------------------|--|--|
| 0        | Use TAAnCCR1 register as compare register |  |  |
| 1        | Use TAAnCCR1 register as capture register |  |  |

| TAAnCCS0 | Operation                                 |  |  |
|----------|-------------------------------------------|--|--|
| 0        | Use TAAnCCR0 register as compare register |  |  |
| 1        | Use TAAnCCR0 register as capture register |  |  |

• Using TAAnCCR1 register as compare register An interrupt is output upon a match between the 16-bit counter and the CCR1 buffer register in the free-running mode (interval function).

Rewrite during compare timer operation is enabled and performed with any time write mode. (Once the compare value has been written,

synchronization with the internal clock is done and this value is used as the 16-bit counter comparison value.)

When timer output (TOAAn1) has been enabled, TOAAn1 performs toggle output upon a match between the 16-bit counter and the CCR1 buffer register.

- Using TAAnCCR1 register as capture register
   The value of the 16-bit counter is saved to the TAAnCCR1 register upon TIAAn1 pin edge detection.
- Using TAAnCCR0 register as compare register
   An interrupt is output upon a match between the 16-bit counter and the CCR0 buffer register in the free-running mode (interval function).

   Rewrite during compare timer operation is enabled and performed with any time write mode. (Once the compare value has been written, synchronization with the internal clock is done and this value is used as the 16-bit counter comparison value.)

   When timer output (TOAAn0) has been enabled, TOAAn0 performs toggle

output upon a match between the 16-bit counter and the CCR0 buffer register.

 Using TAAnCCR0 register as capture register
 The value of the 16-bit counter is saved to the TAAnCCR0 register upon TIAAn0 pin edge detection.





Figure 16-25 Flowchart of basic operation in free-running mode



## (1) When TAAnCCS1 = 0, and TAAnCCS0 = 0 settings (interval function description, compare function)

When TAAnCE = 1 is set, the 16-bit counter counts from 0000H to FFFFH and the free-running count-up operation continues until TAAnCE = 0 is set.

In this mode, when a value is written to the TAAnCCR0 and TAAnCCR1 registers, they are transferred to the CCR0 buffer register and the CCR1 buffer register (any time write mode). In this mode, no one-shot pulse is output even when an one-shot pulse trigger is input. Moreover, when TAAnOEm = 1 is set, TOAAnm performs toggle output upon a match between the 16-bit counter and the CCRm buffer register.



### Figure 16-26 Basic Operation Timing In Free-running Mode (TAAnCCS1 = 0, TAAnCCS0 = 0) (TAAnOE0 = 1, TAAnOE1 = 1, TAAnOL0 = 0, TAAnOL1 = 0)

D00, D01: Setting values of TAAnCCR0 register (0000H to FFFFH) D10, D11: Setting values of TAAnCCR1 register (0000H to FFFFH)

TOAAnm output goes high when counting is started.

**Note** n = 0 to 9; m = 0, 1



# (2) When TAAnCCS1 = 1 and TAAnCCS0 = 1 settings (capture function description)

When TAAnCE = 1, the 16-bit counter counts from 0000H to FFFFH and freerunning count-up operation continues until TAAnCE = 0 is set. During this time, values are captured by capture trigger operation and are written to the TAAnCCR0 and TAAnCCR1 registers.

Regarding capture close to the overflow (FFFFH), judgment is made using the overflow flag (TAAnOVF). However, if overflow occurs twice (two or more freerunning cycles), the capture trigger interval cannot be judged with the TAAnOVF flag. In this case, the system should be revised.



Figure 16-27 Basic operation timing in free-running mode (TAAnCCS1 = 1, TAAnCCS0 = 1) (TAAnOE0 = 1, TAAnOE1 = 1, TAAnOL0 = 0, TAAnOL1 = 0)

> D00, D01, D02, D03: Values captured to TAAnCCR0 register (0000H to FFFFH) D10, D11, D12: Values captured to TAAnCCR1 register (0000H to FFFFH)

TIAAn0: Set to rising edge detection (TAAnIS1, TAAnIS0 = 01) TIAAn1: Set to falling edge detection (TAAnIS3, TAAnIS2 = 10)



### (3) When TAAnCCS1 = 1 and TAAnCCS0 = 0

When TAAnCE = 1 is set, the counter counts from 0000H to FFFFH and freerunning count-up operation continues until TAAnCE = 0 is set. The TAAnCCR0 register is used as a compare register. An interrupt signal is output upon a match between the value of the 16-bit counter and the setting value transferred to the CCR0 buffer register from the TAAnCCR0 register as an interval function. Even if TAAnOE1 = 1 to realize the output function, TAAnCCR1 register cannot control TOAAn1 because it is used as capture register.



Figure 16-28

Basic operation timing in free-running mode (TAAnCCS1 = 1, TAAnCCS0 = 0) (TAAnOE0 = 1, TAAnOE1 = 1, TAAnOL0 = 0, TAAnOL1 = 0)

D00, D01: Setting compare values of TAAnCCR0 register (0000H to FFFH) D10, D11, D12, D13, D14, D15: Values captured to TAAnCCR1 register (0000H to FFFH)

TIAAn1:

Set to detection of both rising and falling edges (TAAnIS3, TAAnIS2 = 11)



### (4) When TAAnCCS1 = 0 and TAAnCS0 = 1

When TAAnCE is set to 1, the 16-bit counter counts from 0000H to FFFFH and free-running count-up operation continues until TAAnCE = 0 is set. The TAAnCCR1 register is used as a compare register. An interrupt signal is output upon a match between the value of the 16-bit counter and the setting value of the TAAnCCR1 register as an interval function. When TAAnOE1 = 1 is set, TOAAn1 performs toggle output upon mach between the value of the 16-bit counter and the setting value of the TAAnCCR1 register.

Even if TAAnOE0 = 1 to realize the output function, TAAnCCR0 register cannot control TOAAn0 because it is used as capture register.



Figure 16-29 Basic operation timing in free-running mode (TAAnCCS1 = 0, TAAnCCS0 = 1) (TAAnOE0 = 1, TAAnOE1 = 1, TAAnOL0 = 0, TAAnOL1 = 0)

> D00, D01, D02, D03: Values captured to TAAnCCR0 register (0000H to FFFH) D10, D11, D12: Setting compare value of TAAnCCR1 register (0000H to FFFFH) TIAAn0: Set to falling edge detection (TAAnIS1, TAAnIS0 = 10)

### (5) Overflow flag

When the counter overflows from FFFFH to 0000H in the free-running mode, the overflow flag (TAAnOVF) is set to 1 and an overflow interrupt (INTTAAnOV) is output.

The overflow flag is cleared by the CPU when writing 0 to it.



### 16.6.8 Pulse width measurement mode (TAAnMD2 to TAAnMD0 = 110B)

In the pulse width measurement mode, free-running count is performed. The value of the 16-bit counter is saved to capture register 0 (TAAnCCR0), or capture register 1 (TAAnCCR1) respectively, and the 16-bit counter is cleared upon edge detection of the TIAAn0 pin, or TIAAn1 respectively. The external input pulse width can be measured as a result.

However, when measuring a large pulse width that exceeds 16-bit counter overflow, perform judgment with the overflow flag. Since measurement of pulses for which overflow occurs twice or more is not possible, adjust the operating frequency of the 16-bit counter.

Depending on the selected capture input sources and specified edge detection three different measurement methods can be applied.

- 1. Pulse period measurement
- 2. Alternating pulse width and pulse space measurement: This requires a fast interrupt handling, in order to measure pulse width and pulse space correctly.
- Simultaneous pulse width and pulse space measurement: Both capture inputs are required to measure pulse width and pulse space simultaneously.

The measurements methods are explained in the following sub-chapters.

**Caution** In the pulse width measurement mode, select the internal clock (TAAnEEE of TAAnCTL1 register = 0).



### (1) Pulse period measurement

The pulse period of a signal can be measured in the pulse width measurement mode, when the edge detection of one of the inputs TIAAn0 and TIAAn1 is set either to "rising edge" or "falling edge". The detection of the other input should be set to "no edge detection".

By detection of the specified edge the resulting value is captured in the corresponding capture register (TAAnCCR0 or TAAnCCR1), and the timer is cleared and restarts counting.



Figure 16-30 Flowchart of pulse period measurement

- External pulse input is possible for both TIAAn0 and TIAAn1, but only one should be selected for the pulse period measurement.
   Specify either "rising edge" or "falling edge" for edge detection. Specify the edge of the external input pulse that is not used as "no edge detection".
  - 2. n = 0 to 9; m = 0, 1





Figure 16-31 Basic operation timing of pulse period measurement

D<sub>00</sub>, D<sub>01</sub>, D<sub>02</sub>: Values captured to TAAnCCR0 register (0000H to FFFH)

TIAAn0: Set to detection of rising edge (TAAnIS1, TAAnIS0 = 01B) TIAAn1: Set to no edge detection (TAAnIS3, TAAnIS2 = 00B)



#### (2) Alternating pulse width and pulse space measurement

The pulse period of a signal can be measured in the pulse width measurement mode alternating in one capture register, when the edge detection of one of the inputs TIAAn0 and TIAAn1 is set to "both rising and falling edges". The detection of the other input should be set to "no edge detection".

By detection of a falling or rising edge the resulting value is captured in the corresponding capture register (TAAnCCR0 or TAAnCCR1), and the timer is cleared and restarts counting.



Figure 16-32 Flowchart of alternating pulse width and pulse space measurement

External pulse input is possible for both TIAAn0 and TIAAn1, but only one should be selected for the alternating pulse width and pulse space measurement.
 Specify "both rising and the falling edges" for edge detection. Specify the edge of the external input pulse that is not used as "no edge detection".

2. n = 0 to 9; m = 0, 1





Figure 16-33 Basic operation timing of alternating pulse width and pulse space measurement

 $D_{00}$ ,  $D_{01}$ ,  $D_{02}$ ,  $D_{03}$ ,  $D_{04}$ : Values captured to TAAnCCR0 register (0000H to FFFFH) TIAAn0: Set to detection of both rising and falling edges (TAAnIS1, TAAnIS0 = 11B) TIAAn1: Set to no edge detection (TAAnIS3, TAAnIS2 = 00B)



#### (3) Simultaneous pulse width and pulse space measurement

Pulse width and pulse space can be measure simultaneously in the pulse width measurement mode, when the signal is input to both inputs TIAAn0 and TIAAn1, where both inputs detect opposite edges. Alternatively the signal can be input to TIAAn0 only, when the capture source input selection for capture register 1 is used (refer to *"TAAIC0 - Timer input control register 0" on page 549* and *"TAAIC1 - Timer input control register 1" on page 550* and *"TAAIC2 - Timer input control register 2" on page 551*).

By detection of the specified edge the resulting values of pulse width or pulse space are captured in the corresponding capture registers (TAAnCCR0, TAAnCCR1), and the timer is cleared and restarts counting.



Figure 16-34 Flowchart of simultaneous pulse width and pulse space measurement

- External pulse input must be input to both TIAAn0 and TIAAn1, or to TIAAn0 only, if the internal connection between both inputs is selected. Specify "rising edge" for edge detection of first input, and "falling edge" for the second input, or vice versa.
  - 2. n = 0 to 9; x = 0, 1 y = 0 when x = 1; y = 1 when x = 0





## Figure 16-35 Basic operation timing of simultaneous pulse width and pulse space measurement

**Note** The signal to measure has to be assigned to both inputs, TIAAn0 and TIAAn1. This can be done either by external pin connection, or internally when selecting TIAAn1 input on TIAAn0 pin. In case of internal connection the signal has to be input on TIAAn0 pin.

 $D_{00}$ ,  $D_{01}$ ,  $D_{02}$ : Values captured to TAAnCCR0 register (0000H to FFFH)  $D_{10}$ ,  $D_{11}$ : Values captured to TAAnCCR1 register (0000H to FFFH)

TIAAn0: Set detection to rising edge (TAAnIS1, TAAnIS0 = 01B) TIAAn1: Set detection to falling edge (TAAnIS3, TAAnIS2 = 10B)



### 16.6.9 32-bit Capture in free-running cascade mode

Two Timer AA (TAA0 in combination with one of TAA1 to TAA3, or TAA4 in combination with one of TAA5 to TAA7, or TAA8 and TAA9) can be cascaded to operate as a 32-bit capture timer. In cascade mode, the timer with the lower number (TAA0, TAA4 or TAA8) is used to control the operation (master timer). Both cascaded timers have to be initialized as free-running timers.



Figure 16-36 Block diagram of TAAm and TAAn in 32-bit capture mode



- Note 1. m = 0, 4, or 8 n = 1 to 3, when m = 0
  - n = 5 to 7, when m = 4 n = 9, when m = 8
  - 2. Explanation of signals can be found in Figure 16-1 on page 543.
  - 3. Block diagrams of the input circuits can be found in *Figure 16-2 on page 544* and *Figure 16-3 on page 544*,

*Figure 16-36* shows the block diagram of TAAm and TAAn in cascade mode. Signals that are irrelevant in cascade mode are not shown, the connections to the internal bus are also hidden for better readability of the image, as *Figure 16-1 on page 543* can be used for a in-depth look of each timer.

**Note** Cascading of two TAA is only allowed for free-running mode with both capture/compare registers set to capture mode. Proper operation of TAAm and TAAn is not guaranteed for any other setting.

*Figure 16-37* shows the recommended flow for setting up TAAm and TAAn in cascade mode. As TAAm is used for general control, TAAn is set up first and set in cascaded operation by setting the TAAnCSE bit to 1. Then TAAm is initialized by selecting the proper clock setting and capture trigger input. Only TIAAm0 and TIAAm1 can be used as external capture trigger.

Note When cascading TAAm and TAAn, set TAAnCSE=1 and TAAmCSE=0.

Operation starts when the count enable flag of TAAm (TAAmCE) is set to 1. The counter of TAAm is used for the lower 16-bit of the 32-bit count value, while the upper 16-bit are handled by TAAn.

Whenever the counter of TAAm overflows, the counter is cleared to 0, interrupt INTTAAmOV is generated and the counter of TAAn is incremented by 1. When the counter of TAAn overflows, the counter is also cleared to 0 and interrupt INTTAAnOV is generated.

When a capture trigger 0/1 is detected by TAAm, a capture of the lower 16-bit counter value to TAAmCCR0/1 and of the upper 16-bit counter value to TAAnCCR0/1 at the same time. The interrupts of the TAAm will indicate the capture (INTTAAmCC0/1).

Figure 16-38 on page 603 shows an example of a 32-bit capture timing.





Figure 16-37 Basic flow of 32-bit capture mode



|                         | TAAmCE = 1                                                                                                     |
|-------------------------|----------------------------------------------------------------------------------------------------------------|
| FFFFH                   | D10 D02                                                                                                        |
| 16-bit counter<br>TMAAm | D <sub>00</sub><br>D <sub>01</sub><br>D <sub>12</sub><br>D <sub>12</sub><br>D <sub>12</sub><br>D <sub>12</sub> |
| FFFFH                   |                                                                                                                |
| 16-bit counter<br>TMAAn | 0000H 0002H                                                                                                    |
| TIAAm0                  |                                                                                                                |
| TAAmCCR0                | 0000H Doo Do1 Do2 Do3                                                                                          |
| TAAnCCR0                |                                                                                                                |
|                         |                                                                                                                |
| TIAAm1                  |                                                                                                                |
| TAAmCCR1                | 0000H D10 D11 D12                                                                                              |
| TAAnCCR1                | 0000H 0002H 0002H                                                                                              |
| INTTAAmCC0              |                                                                                                                |
| INTTAAmCC1              |                                                                                                                |
| INTTAAmOV               |                                                                                                                |
| INTTAAnOV               | L                                                                                                              |
| TOAAm0<br>TOAAn0        |                                                                                                                |
| TOAAm1<br>TOAAn1        | L                                                                                                              |

Figure 16-38 Basic timing of 32-bit capture mode

Note m = 0, 4, or 8 n = 1 to 3, when m = 0 n = 5 to 7, when m = 4n = 9, when m = 8

As the 32-bit resolution is achieved by cascading two individual TAA, a direct read of the 32-bit capture value is not possible. To ensure that the data is not corrupted during read operation, the following procedure for reading needs to be followed:





Figure 16-39 Flow of 32-bit read (capture or counter value)

Disabling the capture interrupt (INTTAAmCCR0/1) is not required if the read sequence is done in the interrupt service routine, as nesting of the same interrupt is not possible. However, if the read operation is done in a normal routine while the interrupt signal is also assigned to a interrupt service routine, disabling the interrupt is mandatory, otherwise corrupted data might be read.

The same flow can be used for reading the timer counter value. In this case the relevant interrupt which pending flags needs to be cleared and checked is INTTAAmOV. Please note that you can either read the upper 16-bit counter (TAAnCNT) and then the lower 16-bit counter (TAAmCNT) or vice versa. While both methods work, the read values can be slightly different, as the count operation of the lower 16-bit counter continues while the upper 16-bit timer is read:

- When reading the upper 16-bit first, the lower 16-bit might be incremented during that read.
- When reading the lower 16-bit first, the value might be already "old" after reading the upper 16-bit.

The software programmer needs to decide which method is considered better for the application.

### 16.6.10 Specific TAAnCCRm overflow value write

This section describes some examples of the specific overflow valu write function.

### (1) General operation

Conditions

ns • TAAnIOC1.TAAnIS[1:0] = 01<sub>B</sub>: TIAAn0 rising edge detection

- TAAnIOC1.TAAnIS[3:2] = 10<sub>B</sub>: TIAAn1 falling edge detection
- TAAnSVC.TAAnCSD0 = 0: TAAnCCR0 always overwritten upon overflow
- TAAnSVC.TAAnCSD1 = 0: TAAnCCR1 always overwritten upon overflow
- TAAnSVC.TAAnCSR0 = 0: OVFV for TAAnCCR0 not reversed
- TAAnSVC.TAAnCSR1 = 0: OVFV for TAAnCCR1 not reversed
- TAAnSVC.TAAnENCm = 1: overflow value write function enabled
- TAAnSVC.TAAnCSE0 = 0: OVFV = 0x0000, if TIAnm = L at overflow
- TAAnSVC.TAAnCSE1 = 1: OVFV = 0xFFFF, if TIAnm = H at overflow
  - TAAnCTL0.TAAnCE = 1: enable TAAn operation



Figure 16-40 Specific overflow value write: general operation

OVF1 TAAnCCR0 = 0x0000, because TAAnCSE0 = L and TIAnm = H

OVF2 TAAnCCR1 = 0xFFFF, because TAAnCSE1 = L and TIAnm = H

### (2) Concurrent capture edge and overflow

When an overflow and a valid edge at the TIAnm input is detected concurrently, the capture operation has priority and the the overflow value is not written to TAAnCCRm. Thus no overflow interrupt INTTAAnOV is generated.

**Conditions** • TAAnIOC1.TAAnIS[1:0] = 01<sub>B</sub>: TIAAn0 rising edge detection

- TAAnIOC1.TAAnIS[3:2] = 10<sub>B</sub>: TIAAn1 falling edge detection
- TAAnSVC.TAAnCSD0 = 0: TAAnCCR0 always overwritten upon overflow
- TAAnSVC.TAAnCSD1 = 0: TAAnCCR1 always overwritten upon overflow
- TAAnSVC.TAAnCSR0 = 0: OVFV for TAAnCCR0 not reversed
- TAAnSVC.TAAnCSR1 = 0: OVFV for TAAnCCR1 not reversed
- TAAnSVC.TAAnENCm = 1: overflow value write function enabled
- TAAnSVC.TAAnCSE0 = 0: OVFV = 0x0000, if TIAnm = L at overflow
- TAAnSVC.TAAnCSE1 = 1: OVFV = 0xFFFF, if TIAnm = H at overflow
- TAAnCTL0.TAAnCE = 1: enable TAAn operation



Figure 16-41 Specific overflow value write: concurrent capture edge and overflow

- **OVF1** Though the counter overflows, D4 = 0xFFFF is captured in TAAnCCR1 because of a valid falling edge at TIAn1. Thus no overflow interrupt INTTAAnOV is generated.
- **OVF2** Though the counter overflows, D5 = 0xFFFF is captured in TAAnCCR0 because of a valid rising edge at TIAn0.

#### Capture edge imemdiately after overflow (3)

In case an overflow event is immediately followed by a valid capture edge, i.e. with the next count clock, the specified overflow value remains in the concerned TAAnCCRm register for a single count clock, as the valid capture edge captures stores the counter value to the TAAnCCRm.

**Conditions** 

- TAAnIOC1.TAAnIS[1:0] = 01<sub>B</sub>: TIAAn0 rising edge detection
  - TAAnIOC1.TAAnIS[3:2] = 10<sub>B</sub>: TIAAn1 falling edge detection
  - TAAnSVC.TAAnCSD0 = 0: TAAnCCR0 always overwritten upon overflow
  - TAAnSVC.TAAnCSD1 = 0: TAAnCCR1 always overwritten upon overflow
  - TAAnSVC.TAAnCSR0 = 0: OVFV for TAAnCCR0 not reversed
  - TAAnSVC.TAAnCSR1 = 0: OVFV for TAAnCCR1 not reversed
  - TAAnSVC.TAAnENCm = 1: overflow value write enabled
  - TAAnSVC.TAAnCSE0 = 0: rising edge
  - TAAnSVC.TAAnCSE0 = 1: falling edge
  - TAAnCTL0.TAAnCE = 1: enable TAAn operation



Figure 16-42 Specific overflow value write: capture edge immediately after overflow

OVF1 TAAnCCR0 is set to overflow value OVFV = 0x0000 (TIAnm = H and TAAnCSE0 = 0) and TAAnCCR1 is set to overflow value OVFV = 0xFFFF (TIAnm = H and TAAnCSE1 = 1).The immediately following falling edge of TIAm, valid for capture channel 1, captures D<sub>4</sub> = 0x0000 in TAACCR1, while TAAnCCR0 remains with the overflow value 0x0000.

**OVF2** TAAnCCR0 is set to overflow value OVFV = 0xFFFF (TIAnm = L and TAAnCSE0 = 0) and TAAnCCR1 is set to overflow value OVFV = 0x0000 (TIAnm = L and TAAnCSE1 = 1). The immediately following rising edge of TIAm, valid for capture channel 0, captures  $D_5 = 0x0000$  in TAACCR0, while TAAnCCR1 remains with the overflow value 0x0000.



### (4) TAAnCCRm overwrite prohibition

Conditions

- TAAnIOC1.TAAnIS[1:0] = 01<sub>B</sub>: TIAAn0 rising edge detection
   TAAnIOC1.TAAnIS[3:2] = 10<sub>B</sub>: TIAAn1 falling edge detection
- TAAnSVC.TAAnCSD0 = 0: TAAnCCR0 always overwritten upon overflow
- TAAnSVC.TAAnCSD1 = 1: TAAnCCR1 overwritten upon overflow and if TIAnm = not(TAAnCSE1)
- TAAnSVC.TAAnCSR0 = 0: OVFV for TAAnCCR0 not reversed
- TAAnSVC.TAAnCSR1 = 0: OVFV for TAAnCCR1 not reversed
- TAAnSVC.TAAnENCm = 1: overflow value write enabled
- TAAnSVC.TAAnCSE0 = 0: rising edge
- TAAnSVC.TAAnCSE0 = 1: falling edge
- TAAnCTL0.TAAnCE = 1: enable TAAn operation



Figure 16-43 Specific overflow value write: TAAnCCRm overwrite prohibition

- **OVF1** TAAnCCR0 is set to overflow value OVFV = 0x0000 (TIAnm = H and TAAnCSE0 = 0) and TAAnCCR1 is set to overflow value OVFV = 0xFFFF (TIAnm = H and TAAnCSE1 = 1).
- OVF2 TAAnCCR0 is set to overflow value OVFV = 0xFFFF (TIAnm = L and TAAnCSE0 = 0). TAAnCCR1 is not overwritten since TAAnCSD1 = 1, TAInm = L while TAAnCSE1 = 1.

### (5) Overflow value write without overflow event

The setting of TAAnSVC.TAAnCSEm does not impact normal capture behaviour, if no overlow occurs.

- **Conditions** TAAnIOC1.TAAnIS[1:0] = 01<sub>B</sub>: TIAAn0 rising edge detection
  - TAAnIOC1.TAAnIS[3:2] = 10<sub>B</sub>: TIAAn1 falling edge detection
  - TAAnSVC.TAAnENCm = 1: overflow value write enabled



Figure 16-44 Specific overflow value write:

• Changing the value of TAAnSVC.TAAnCSELm has no influence to the normal capture operation, if no overflow event occurs.



### 16.7 Timer Synchronization Operation Function

Timers AA have a timer synchronized operation function (tuned operation mode). Master timer and incorporated slave timers of the corresponding timer group (listed in *Table 16-16*) start and clock synchronously. When the master timer is cleared, the slave timers are cleared synchronously, too.

### Table 16-16 Tuned Operation Mode of Timer

| Master Timer | Slave Timer |      |      |  |  |
|--------------|-------------|------|------|--|--|
| TAA0         | TAA1        | TAA2 | TAA3 |  |  |
| TAA4         | TAA5        | TAA6 | TAA7 |  |  |

Caution 1. The tuned operation mode is enabled or disabled by the TAAnSYE bit of the TAAnCTL1 register.

- 2. Set the tuned operation mode using the following procedure.
  - Set the TAAnSYE bit of the TAAnCTL1 register of the slave timer to enable the tuned operation. Set the TAAnMD2 to TAAnMD0 bits of the TAAnCTL1 register of the slave timer to the free-running mode (101B).
  - Set the timer mode of the master timer by using the TAAnMD2 to TAAnMD0 bits of the TAAnCTL1 register to PWM mode (110B), external trigger pulse output mode (010B), or free-running mode (101B). At this time, do not set the TAAnSYE bit of the TAAnCTL1 register of the master timer.
  - Set the compare register value of the master and slave timers.
  - Set the TAAnCE bit of the TAAnCTL0 register of the slave timer to enable operation on the internal operating clock.
  - Set the TAAnCE bit of the TAAnCTL0 register of the master timer to enable operation on the internal operating clock.

*Table 16-17* and *Table 16-18* show the timer modes that can be used in the tuned operation mode

( $\sqrt{}$ : settable,  $\times$ : not settable).

### Table 16-17 Timer modes usable in tuned operation mode

| Master Timer | Free-Running Mode | PWM Mode     | External Trigger<br>Pulse Output<br>Mode |  |
|--------------|-------------------|--------------|------------------------------------------|--|
| TAA0         | $\checkmark$      | $\checkmark$ |                                          |  |
| TAA4         | $\checkmark$      | $\checkmark$ |                                          |  |

**Note** The timing of transmitting data from the compare register of the master timer to the compare register of the slave timer is as follows.

PPG: Toggle, PWM: CPU write timing (anytime write mode) Timing at which timer counter and compare register match TOAAn0 (n = 0 to 9) (reload mode)



### Table 16-18 Timer output functions

| Tuned          |                  | Pin    | Free-Running Mode |              | PWM Mode      |              |
|----------------|------------------|--------|-------------------|--------------|---------------|--------------|
| Timer<br>Group | Timer            |        | Tuning<br>OFF     | Tuning ON    | Tuning<br>OFF | Tuning ON    |
| 0              | TAA0<br>(master) | TOAA00 | PPG               | ←            | Toggle        | $\leftarrow$ |
|                |                  | TOAA01 | PPG               | ←            | PWM           | ←            |
|                | TAA1<br>(slave)  | TOAA10 | PPG               | ←            | Toggle        | PWM          |
|                |                  | TOAA11 | PPG               | ←            | PWM           | ←            |
|                | TAA2<br>(slave)  | TOAA20 | PPG               | ←            | Toggle        | PWM          |
|                |                  | TOAA21 | PPG               | ←            | PWM           | ←            |
|                | TAA3<br>(slave)  | TOAA30 | PPG               | ←            | Toggle        | PWM          |
|                |                  | TOAA31 | PPG               | ←            | PWM           | <i>←</i>     |
| 1              | TAA4<br>(master) | TOAA40 | PPG               | ←            | Toggle        | <i>←</i>     |
|                |                  | TOAA41 | PPG               | ←            | PWM           | $\leftarrow$ |
|                | TAA5<br>(slave)  | TOAA50 | PPG               | ←            | Toggle        | PWM          |
|                |                  | TOAA51 | PPG               | ←            | PWM           | ←            |
|                | TAA6<br>(slave)  | TOAA60 | PPG               | ←            | Toggle        | PWM          |
|                |                  | TOAA61 | PPG               | ←            | PWM           | ←            |
|                | TAA7<br>(slave)  | TOAA70 | PPG               | ←            | Toggle        | PWM          |
|                |                  | TOAA71 | PPG               | $\leftarrow$ | PWM           | $\leftarrow$ |



# Chapter 17 16-Bit Timer/Event Counter S (TMS)

This microcontroller has two instances of the Timer S (TMS), TMS0 to TMS1.

Note Throughout this chapter, the individual instances of Timer S are identified by "n" (n = 0 to 1), for example TSnCTL1 for the Timer Sn control register 1.

# 17.1 Features

Timer S is a 16-bit timer/counter with Motor Control Functions

- Count clock resolution: Minimum 31.25 ns (using 32 MHz count clock)
- Operation modes supporting general-purpose timer and each motor control method
- Reload buffer-equipped compare register
- 10-bit dead time counter
  - Dead time counter with reload buffer
  - Dead time value independent of positive phase to negative phase or negative phase to positive phase can be set.
- A/D conversion trigger signal generation
  - A/D conversion trigger generated by two compare registers, TSnCCR4 and TSnCCR5
- A/D conversion trigger
  - Individual thinning out function for TSnADTRG0/TSnADTRG1 signal: Thinning out ratio settable to 1/1, 1/2, 1/4, 1/8
  - Dedicated output pins (TOSn7), set with TSnADTRG0 signal and reset with TSnADTRG1 signal
- Interrupt thinning out function
  - Thinning out ratios: 1/1 to 1/32
- Enforced output stop function: ESO
  - Output high impedance of TOSn0 to TOSn7 pins can be executed during ESOn input.
- Compare value setting
  - Reload (batch rewrite function)/anytime rewrite function can be selected<sup>Note</sup>.
- Reload mode
  - Reload is enabled by writing to the TSnCCR1 register (the reload request flag TSnRSF is set) to enable simultaneous transfer of multiple registers
  - Enables transfer at the following reload timings: Peak, trough, and peak and trough<sup>Note</sup>
  - Provides reload request flag TSnRSF
  - Allocates register address enabling DMA transfer
  - Reload thinning out function



- High-accuracy T-PWM mode
  - Enables 0-100% duty PWM output including dead time reduction
  - Improves output resolution without software load because whether or not to use additional pulse(s) in PWM output of count-up operation can be controlled with compare register LSB.
  - Extended operation modes (center method, symmetric interchange method) available for special PWM output behavior, where the duty cycle is split into two phases.
- 180° excitation control
  - Semi-automatic driving function (Enables trigger input from 2-phase encoder and 3-phase encoder)
  - Enables switching from high-accuracy T-PWM mode, 120° excitation mode, or special 120° excitation mode during operation.
- 120° excitation control/Special 120° excitation control
  - Semi-automatic driving function (Enables trigger generation by the offset coordinated with 2-phase encoder, 3-phase encoder, and timer T)
- 3-phase encoder function (Enables signal input such as hall sensor)
- Count clock can be selected from the following 8: fPCLK, fPCLK/2, fPCLK/4, fPCLK/8, fPCLK/16, fPCLK/32, fPCLK/128 and fPCLK/512
- The active level of output pins TOSn0 to TOSn7 can be set individually for each pin.
- Fail safe function (Warning/error interrupt occurrence enabled)
  - Simultaneous active output detection function in positive/negative phase
  - Abnormal input detection function for 3-phase encoder
- **Note** High-accuracy T-PWM mode



# 17.2 Configuration

Timer Sn consists of the following hardware.

## Table 17-1 Timer Sn configuration

| Item                | Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Counter             | 16-bit counter × 1<br>16-bit sub-counter × 1<br>10-bit dead time counter × 3                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Register            | Timer Sn counter read register (TSnCNT)<br>Timer Sn sub-counter read register (TSnSBC)<br>Timer Sn dead time setting registers 0, 0A, 1, 1A (TSnDTC0,<br>TSnDTC0A, TSnDTC1, TSnDTC1A <sup>a</sup> )<br>Timer Sn compare registers 0 to 5 (TSnCCR0 to TSnCCR5,<br>TSnCCR0A to TSnCCR5A <sup>a</sup> )<br>Timer Sn compare registers 0A to 5A (TSnCCR0 to TSnCCR5,<br>TSnCCR0A to TSnCCR5A <sup>a</sup> )<br>Timer Sn compare registers 1B to 3B (TSnCCR1B to<br>TSnCCR3B)<br>Timer Sn pattern registers 0, 1 (TSnPAT0, TSnPAT1) |
| Timer input pin     | 6 pins (TTRGSn, TEVTSn, TAPTSn0 to TAPTSn2, ESOn) <sup>b</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Timer output pin    | 8 pins (TOSn0 to TOSn7) <sup>b</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Timer input signal  | TSnSTCI0, TSnSTCI1, TSnARD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Timer output signal | TSnADTRG0, TSnADTRG1, TSnAEDO, TSnESG, TSnTSF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Control register    | Timer Sn control registers 0, 1 (TSnCTL0, TSnCTL1)<br>Timer Sn I/O control registers 0, 2, 4 (TSnIOC0, TSnIOC2,<br>TSnIOC4)<br>Timer Sn option registers 0 to 7 (TSnOPT0 to TSnOPT7)<br>Timer Sn option register 1A (TSnOPT1, TSnOPT1A <sup>a</sup> )                                                                                                                                                                                                                                                                          |
| Interrupt           | Compare match interrupt (INTTSnCC0 to INTTSnCC5)<br>Peak interrupt (INTTSnCD0)<br>Trough interrupt (INTTSnOD)<br>Overflow interrupt (INTTSnOV)<br>Error interrupt (INTTSnER)<br>Warning interrupt (INTTSnWN)                                                                                                                                                                                                                                                                                                                   |

a) Throughout this manual the register names with an "A" suffix are functional identical to there counterparts without the "A" suffix. Thus all references to register names without suffix are also valid to the registers with suffix.

b) Alternate-function pin





Figure 17-1 Timer Sn block diagram

| TSnCCR0 to TSnCCR5:               | Compare registers 0 to 5                  |
|-----------------------------------|-------------------------------------------|
| TSnCCR0 buffer to TSnCCR5 buffer: | Compare buffer registers 0 to 5           |
| TSnDTC0, TSnDTC1:                 | Timer Sn dead time setting registers 0, 1 |
| TSnSBC:                           | Timer Sn sub-counter read register        |
| TSnCUF:                           | Bit 1 of timer Sn option register 0       |
| TSnSUF:                           | Bit 1 of timer Sn option register 6       |
| INTTSnOD:                         | Trough interrupt                          |
| INTTSnCD0:                        | Peak interrupt                            |
| INTTSnCC1 to INTTSnCC5:           | Compare match interrupts 1 to 5           |
| ESOn:                             | Timer Sn output stop signal input pin     |
| TOSn0 to TOSn7:                   | Timer output pins 0 to 7                  |
| ADC0, ADC1:                       | A/D Converters 0, 1                       |
| DTT1 to DTT3:                     | Dead time counters                        |
|                                   |                                           |



Thinning out:

Thinning out circuit

| Note PCL | Kn: peripheral clocks | (refer to "Clock | Generator" | on page 148): |
|----------|-----------------------|------------------|------------|---------------|
|----------|-----------------------|------------------|------------|---------------|

| PCLK    | 0  | 1  | 2 | 3 | 4 | 5 | 7    | 9      |
|---------|----|----|---|---|---|---|------|--------|
| f [MHz] | 32 | 16 | 8 | 4 | 2 | 1 | 0.25 | 0.0625 |



| Chapter 17    | 16-Bit Timer/Event Counter S (TMS)                                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|
| (1)           | Timer Sn compare register 0, 0A (TSnCCR0, TSnCCR0A)                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |
|               | The TSnCCR0 and TSnCCR0A registers are 16-bit compare registers. The TSnCCR0A register is a mirror of the TSnCCR0 register for optimized DMA support. |  |  |  |  |  |  |  |  |  |  |  |
| Access        | These registers can be read/written in 16-bit units.                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |
| Address       | TS0CCR0: FFFF598 <sub>H</sub><br>TS1CCR0: FFFF5D8 <sub>H</sub><br>TS0CCR0A: FFFFB50 <sub>H</sub><br>TS1CCR0A: FFFFBD0 <sub>H</sub>                    |  |  |  |  |  |  |  |  |  |  |  |
| Initial Value | 0000 <sub>H</sub> . These registers are cleared by any reset.                                                                                         |  |  |  |  |  |  |  |  |  |  |  |
|               | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                 |  |  |  |  |  |  |  |  |  |  |  |
| TSnCCR0/      | Compare value 0                                                                                                                                       |  |  |  |  |  |  |  |  |  |  |  |
| TSnCCR0A      | R/W                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |

Caution Write to bit 0 of the TSnCCR0 register, or TSnCCR0A respectively, is ignored in high-accuracy T-PWM mode.

Bit 0 reads 0.

The write access method for the TSnCCR0 register during the timer Sn operation (when TSnCE of TSnCTL0 register is set to 1) is as follows.

| Timer Sn operation mode                                                                                                                                                                   | TSnCCR0 register write<br>access method  |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|--|--|--|--|--|--|
| PWM mode, external trigger pulse output mode,<br>triangular-wave PWM mode, PWM mode with dead<br>time, 120° excitation mode, special 120° excitation<br>mode, special pattern output mode | Reload                                   |  |  |  |  |  |  |
| Free-running mode, external event count mode, one-<br>shot pulse mode, interval timer mode                                                                                                | Anytime rewrite                          |  |  |  |  |  |  |
| High-accuracy T-PWM mode                                                                                                                                                                  | Reload/anytime rewrite switching enabled |  |  |  |  |  |  |

**Caution** The TSnCCR0 register, or TSnCCR0A respectively, setting must be as follows to set the carrier wave cycle in the high-accuracy T-PWM mode.

TSnCCR0 or TSnCCR0A register value =

Count clock number of carrier wave cycle

- + TSnDTC0 or TSnDTC0A register value
- + TSnDTC1 or TSnDTC1A register value

Refer to *"16-bit counter operation in high-accuracy T-PWM mode" on page 801* for the carrier wave and dead time setting.

**Note 1.** Refer to *"Compare register rewriting" on page 691* for details on the compare register rewriting operation.

RENESAS

2. Throughout this manual the register name TSnCCR0 means also the register TSnCCR0A.



618

Α

#### (2) Timer Sn compare register 1, 1A (TSnCCR1, TSnCCR1A)

The TSnCCR1 and TSnCCR1A registers are 16-bit compare registers. The TSnCCR1A register is a mirror of the TSnCCR1 register for optimized DMA support.

When a compare register is rewritten in the reload mode, the reload request flag (TSnRSF) of TSnOPT6 is set to 1 by write access to the TSnCCR1 register or TSnCCR1A register, and then all of the TSnCCR0 to TSnCCR5, TSnCCR0A to TSnCCR5A, TSnCCR1B to TSnCCR3B, TSnDTC0, TSnDTC1, TSnOPT1, TSnPAT0, and TSnPAT1 registers are rewritten at the next reload timing.

| Access Th | ese registers can | be read/written | in 16-bit units. |
|-----------|-------------------|-----------------|------------------|
|-----------|-------------------|-----------------|------------------|

| ddress | TS0CCR1: | FFFF59E <sub>H</sub> | TS0CCR1A: FFFFFB56 <sub>H</sub> |
|--------|----------|----------------------|---------------------------------|
|        | TS1CCR1: | FFFF5DE <sub>H</sub> | TS1CCR1A: FFFFFBD6 <sub>H</sub> |

Initial Value 0000<sub>H</sub>. These registers are cleared by any reset.

|          | 15 | 14  | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6   | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|----|-----|----|----|----|----|----|-------|--------|-----|---|---|---|---|---|---|
| TSnCCR1/ |    |     |    |    |    |    | Co | mpare | e valu | e 1 |   |   |   |   |   |   |
| TSnCCR1A |    | R/W |    |    |    |    |    |       |        |     |   |   |   |   |   |   |

**Note** Additional pulse control function operates if 1 is set to bit 0 of the TSnCCR1 register or TSnCCR1A register in the high-accuracy T-PWM mode. Refer to *"Additional pulse control in high-accuracy T-PWM mode" on page 805* for the additional pulse control function.

The write access method for the TSnCCR1/TSnCCR1A register during the timer Sn operation (when TSnCE of TSnCTL0 register is set to 1) is as follows.

| Timer Sn operation mode                                                                                                                                                                   | TSnCCR1/TSnCC1A register<br>write access method |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|--|--|--|--|--|--|
| PWM mode, external trigger pulse output mode,<br>triangular-wave PWM mode, PWM mode with<br>dead time, 120° excitation mode, special 120°<br>excitation mode, special pattern output mode | Reload                                          |  |  |  |  |  |  |
| Free-running mode, external event count mode, one-shot pulse mode, interval timer mode                                                                                                    | Anytime rewrite                                 |  |  |  |  |  |  |
| High-accuracy T-PWM mode                                                                                                                                                                  | Reload/anytime rewrite switching enabled        |  |  |  |  |  |  |

- **Note 1.** Refer to *"Compare register rewriting" on page 691* for details on the compare register rewriting operation.
  - 2. Throughout this manual the register name TSnCCR1 means also the register TSnCCR1A.
  - (3) Timer Sn compare register 1B (TSnCCR1B)

The TSnCCR1B register is a 16-bit compare register, which is not used in the current product. Reading or writing to this register does not have any effect.

Access This register can be read/written in 16-bit units.

Address TS0CCR1B: FFFFFB4E<sub>H</sub> TS1CCR1B: FFFFFBCE<sub>H</sub>

**Initial Value** 0000<sub>H</sub>. This register is cleared by any reset.



#### (4) Timer Sn compare register 2, 2A (TSnCCR2, TSnCCR2A)

The TSnCCR2 and TSnCCR2A registers are 16-bit compare registers. The TSnCCR2A register is a mirror of the TSnCCR2 register for optimized DMA support.

Access These registers can be read/written in 16-bit units.

| Address | TS0CCR2: | FFFF59C <sub>H</sub> | TS0CCR2A: FFFFFB54 <sub>H</sub> |
|---------|----------|----------------------|---------------------------------|
|         | TS1CCR2: | FFFF5DC <sub>H</sub> | TS1CCR2A: FFFFFBD4 <sub>H</sub> |

Initial Value 0000<sub>H</sub>. These registers are cleared by any reset.

|          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6   | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|----|----|----|----|----|----|----|-------|--------|-----|---|---|---|---|---|---|
| TSnCCR2/ |    |    |    |    |    |    | Co | mpare | e valu | e 2 |   |   |   |   |   |   |
| TSnCCR2A |    |    |    |    |    |    |    | R/    | W      |     |   |   |   |   |   |   |

**Note** The additional pulse control function operates if 1 is set to bit 0 of the TSnCCR2 register or TSnCCR2A register in the high-accuracy T-PWM mode. Refer to *"Additional pulse control in high-accuracy T-PWM mode" on page 805* for the additional pulse control function.

The write access method for the TSnCCR2/TSnCCR2A register during the timer Sn operation (when TSnCE of TSnCTL0 register is set to 1) is as follows.

| Timer Sn operation mode                                                                                                                                                                   | TSnCCR2/TSnCCR2A<br>register write access method |  |  |  |  |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------|--|--|--|--|--|--|--|
| PWM mode, external trigger pulse output mode,<br>triangular-wave PWM mode, PWM mode with dead<br>time, 120° excitation mode, special 120° excitation<br>mode, special pattern output mode | Reload                                           |  |  |  |  |  |  |  |
| Free-running mode, external event count mode, one-shot pulse mode, interval timer mode                                                                                                    | Anytime rewrite                                  |  |  |  |  |  |  |  |
| High-accuracy T-PWM mode                                                                                                                                                                  | Reload/anytime rewrite switching enabled         |  |  |  |  |  |  |  |

- **Note 1.** Refer to *"Compare register rewriting" on page 691* for details on the compare register rewriting operation.
  - 2. Throughout this manual the register name TSnCCR2 means also the register TSnCCR2A.

#### (5) Timer Sn compare register 2B (TSnCCR2B)

The TSnCCR2B register is a 16-bit compare register, which is not used in the current product. Reading or writing to this register does not have any effect.

- Access This register can be read/written in 16-bit units.
- Address TS0CCR2B: FFFFFB4C<sub>H</sub> TS1CCR2B: FFFFFBCC<sub>H</sub>
- Initial Value 0000<sub>H</sub>. This register is cleared by any reset.



#### (6) Timer Sn compare register 3, 3A (TSnCCR3, TSnCCR3A)

The TSnCCR3 and TSnCCR3A registers are 16-bit compare registers. The TSnCCR3A register is a mirror of the TSnCCR3 register for optimized DMA support.

Access These registers can be read/written in 16-bit units.

| Address | TS0CCR3: | FFFF59A <sub>H</sub> | TS0CCR3A: FFFFFB52 <sub>H</sub> |
|---------|----------|----------------------|---------------------------------|
|         | TS1CCR3: | FFFF5DA <sub>H</sub> | TS1CCR3A: FFFFFBD2 <sub>H</sub> |

Initial Value 0000<sub>H</sub>. These registers are cleared by any reset.

|          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6   | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|----|----|----|----|----|----|----|-------|--------|-----|---|---|---|---|---|---|
| TSnCCR3/ |    |    |    |    |    |    | Co | mpare | e valu | e 3 |   |   |   |   |   |   |
| TSnCCR3A |    |    |    |    |    |    |    | R/    | W      |     |   |   |   |   |   |   |

**Note** Additional pulse control function operates if 1 is set to bit 0 of the TSnCCR3 register or TSnCCR3A register in the high-accuracy T-PWM mode. Refer to *"Additional pulse control in high-accuracy T-PWM mode" on page 805* for the additional pulse control function.

The write access method for the TSnCCR3/TSnCCR3A register during the timer Sn operation (when TSnCE of TSnCTL0 register is set to 1) is as follows.

| Timer Sn operation mode                                                                                                                                                                   | TSnCCR3B register write<br>access method |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|
| PWM mode, external trigger pulse output mode,<br>triangular-wave PWM mode, PWM mode with dead<br>time, 120° excitation mode, special 120° excitation<br>mode, special pattern output mode | Reload                                   |
| Free-running mode, external event count mode, one-shot pulse mode, interval timer mode                                                                                                    | Anytime rewrite                          |
| High-accuracy T-PWM mode                                                                                                                                                                  | Reload/anytime rewrite switching enabled |

- **Note 1.** Refer to *"Compare register rewriting" on page 691* for details on the compare register rewriting operation.
  - 2. Throughout this manual the register name TSnCCR3 means also the register TSnCCR3A.

#### (7) Timer Sn compare register 3B (TSnCCR3B)

The TSnCCR3B register is a 16-bit compare register, which is not used in the current product. Reading or writing to this register does not have any effect.

- Access This register can be read/written in 16-bit units.
- Address TS0CCR3B: FFFFFB4A<sub>H</sub> TS1CCR3B: FFFFFBCA<sub>H</sub>
- Initial Value 0000<sub>H</sub>. This register is cleared by any reset.



## (8) Timer Sn compare register 4, 4A (TSnCCR4, TSnCCR4A)

The TSnCCR4 and TSn CCR4A registers are 16-bit compare registers. The TSnCCR4A register is a mirror of the TSnCCR4 register for optimized DMA support.

The match interrupt signal of the 16-bit counter and the TSnCCR4 or TSnCCR4A register can be selected as the A/D conversion trigger in the highaccuracy T-PWM mode, PWM mode with dead time, special 120° excitation mode, and special pattern output mode.

Access These registers can be read/written in 16-bit units.

| Address | TS0CCR4: | FFFFF592 <sub>H</sub> | TS0CCR4A: FFFFFB48 <sub>H</sub> |
|---------|----------|-----------------------|---------------------------------|
|         | TS1CCR4: | FFFF5D2 <sub>H</sub>  | TS1CCR4A: FFFFFBC8 <sub>H</sub> |

Initial Value 0000<sub>H</sub>. These registers are cleared by any reset.

|          | 15      | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6   | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|---------|----|----|----|----|----|----|-------|--------|-----|---|---|---|---|---|---|
| TSnCCR4/ |         |    |    |    |    |    | Со | mpare | e valu | e 4 |   |   |   |   |   |   |
| TSnCCR4A | SnCCR4A |    |    |    |    |    |    |       |        |     |   |   |   |   |   |   |

**Note** Bit 0 of the TSnCCR4 and TSnCCR4A registers is ignored in the highaccuracy T-PWM mode.

The write access method for the TSnCCR4/TSnCCR4A register during the timer Sn operation (when TSnCE of TSnCTL0 register is set to 1) is as follows.

| Timer Sn operation mode                                                                                                                                                                   | TSnCCR4/TSnCCR4A register write access method |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|
| PWM mode, external trigger pulse output mode,<br>triangular-wave PWM mode, PWM mode with dead<br>time, 120° excitation mode, special 120° excitation<br>mode, special pattern output mode | Reload                                        |
| Free-running mode, external event count mode, one-shot pulse mode, interval timer mode                                                                                                    | Anytime rewrite                               |
| High-accuracy T-PWM mode                                                                                                                                                                  | Reload/anytime rewrite switching enabled      |

- **Note 1.** Refer to *"Compare register rewriting" on page 691* for details on the compare register rewriting operation.
  - 2. Throughout this manual the register name TSnCCR4 means also the register TSnCCR4A.



## (9) Timer Sn compare register 5, 5A (TSnCCR5, TSnCCR5A)

The TSnCCR5 and TSnCCR5A registers are 16-bit compare register. The TSnCCR5A register is a mirror of the TSnCCR5 register for optimized DMA support.

The match interrupt signal of the 16-bit counter and the TSnCCR5 register, or TSnCCR5A register respectively, can be selected as the A/D conversion trigger in the high-accuracy T-PWM mode, PWM mode with dead time, special 120° excitation mode, and special pattern output mode.

Access These registers can be read/written in 16-bit units.

| Address | TS0CCR5: | FFFF590 <sub>H</sub> | TS0CCR5A: FFFFFB46 <sub>H</sub> |
|---------|----------|----------------------|---------------------------------|
|         | TS1CCR5: | FFFF5D0 <sub>H</sub> | TS1CCR5A: FFFFFBC6 <sub>H</sub> |

Initial Value 0000<sub>H</sub>. These registers are cleared by any reset.

|          | 15  | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6   | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|-----|----|----|----|----|----|----|-------|--------|-----|---|---|---|---|---|---|
| TSnCCR5/ |     |    |    |    |    |    | Co | mpare | e valu | e 5 |   |   |   |   |   |   |
| TSnCCR5A | R/W |    |    |    |    |    |    |       |        |     |   |   |   |   |   |   |

**Note** Bit 0 of the TSnCCR5 or TsnCCR5A register is ignored in the high-accuracy T-PWM mode.

The write access method for the TSnCCR5/TSnCCR5A register during the timer Sn operation (when TSnCE of TSnCTL0 register is set to 1) is as follows.

| Timer Sn operation mode                                                                                                                                                                   | TSnCCR5/TSnCCR5A register write access method |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|
| PWM mode, external trigger pulse output mode,<br>triangular-wave PWM mode, PWM mode with dead<br>time, 120° excitation mode, special 120° excitation<br>mode, special pattern output mode | Reload                                        |
| Free-running mode, external event count mode, one-shot pulse mode, interval timer mode                                                                                                    | Anytime rewrite                               |
| High-accuracy T-PWM mode                                                                                                                                                                  | Reload/anytime rewrite switching enabled      |

- **Note 1.** Refer to *"Compare register rewriting" on page 691* for details on the compare register rewriting operation.
  - 2. Throughout this manual the register name TSnCCR5 means also the register TSnCCR5A.



#### (10) Timer Sn counter read register (TSnCNT)

The TSnCNT register is a timer read register that can read the 16-bit main counter value.

Access This register can be read only in 16-bit units.

| Address | TS0CNT: | FFFFF5A6 <sub>H</sub> |
|---------|---------|-----------------------|
|         | TS1CNT: | FFFFF5E6              |

Initial Value 0000<sub>H</sub>. This register is cleared by any reset, or when TSnCTL0.TSnCE is set to 0.

The TSnCNT register is set to FFFFH (or FFFEH in the high-accuracy T-PWM mode) in the interval from when from TSnCTL0.TSnCE is set to 1 until the count-up operation starts.

|        | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3    | 2 | 1 | 0 |
|--------|---------------|----|----|----|----|----|---|---|---|---|---|---|------|---|---|---|
| TSnCNT | Counter value |    |    |    |    |    |   |   |   |   |   |   | Note |   |   |   |
| B/W    |               |    |    |    |    |    |   |   |   |   |   |   |      |   |   |   |

Note Bit 0 reads 0 in the high-accuracy T-PWM mode.

### (11) Timer Sn sub-counter read register (TSnSBC)

The TSnSBC register can read the 16-bit sub counter value.

- **Note** This register is operable only in the high-accuracy T-PWM mode or PWM mode with dead-time.
- Access This register can be read only in 16-bit units.
- Address TS0SBC: FFFFF5A8<sub>H</sub> TS1SBC: FFFFF5E8<sub>H</sub>
- Initial Value 0000<sub>H</sub>. This register is cleared by any reset, or when TSnCTL0.TSnCE is set to 0.

|           | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
|-----------|-----|----|----|----|----|----|---|-------------------|---|---|---|---|---|---|---|------|
| TSnSBC Su |     |    |    |    |    |    |   | Sub-counter value |   |   |   |   |   |   |   | Note |
|           | R/W |    |    |    |    |    |   |                   |   |   |   |   |   |   |   |      |

Note Bit 0 reads 0 in the high-accuracy T-PWM mode.



#### (12) Timer Sn dead time setting register 0, 0A (TSnDTC0, TSnDTC0A)

The TSnDTC0 and TSnDTC0A registers are 10-bit register which specify the dead time value. The TSnDTC0A register is a mirror of the TSnDTC0 register for optimized DMA support.

Access These registers can be read/written in 16-bit units.

| Address | TS0DTC0: | FFFF58E <sub>H</sub> | TS0DTC0A: FFFFFB44 <sub>H</sub> |
|---------|----------|----------------------|---------------------------------|
|         | TS1DTC0: | FFFF5CE <sub>H</sub> | TS1DTC0A: FFFFFBC4 <sub>H</sub> |

Initial Value 0000<sub>H</sub>. These registers are cleared by any reset.

|          | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7  | 6     | 5      | 4      | 3 | 2 | 1 | 0 |
|----------|----|----|----|----|----|----|---|----|----|-------|--------|--------|---|---|---|---|
| TSnDTC0/ | 0  | 0  | 0  | 0  | 0  | 0  |   |    | [  | Dead- | time \ | alue ( | 0 |   |   | 0 |
| TSnDTC0A |    |    |    |    |    |    |   | R/ | /W |       |        |        |   |   |   |   |

**Note** Throughout this manual the register name TSnDTC0 means also the register TSnDTC0A.

Caution 1. The dead time counter is enabled only in the PWM mode (TSnDSE of the TSnOPT0 register is set to 1), high-accuracy T-PWM mode, PWM mode with dead time, 120° excitation mode, special 120° excitation mode, and special pattern output mode (TSnDSE of the TSnOPT0 register is set to 1). In the other modes, be sure to set the TSnDTC0 register, or TSnDTC0A register respectively, to 0000H.

- 2. Refer to *"Rewriting of TSnDTC0 and TSnDTC1 registers" on page 827* regardless of any operation mode of timer Sn when TSnDTC0, or TSnDTC0A register respectively, is rewritten to another value during operation of timer Sn (when TSnCE of the TSnCTL0 register is set to 1).
- **3.** Dead time is not inserted when the TSnDTC0 register, or TSnDTC0A register respectively, is set to 0000H.

4. Bits 15 to 10 and 0 are fixed to 0.



| apter 17      | 16-Bit Timer/Event Counter S (TMS)                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| (13)          | Timer Sn dead time setting register 1, 1A (TSnDTC1, TSnDTC1A)                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
|               | The TSnDTC1 and TSnDTC1A registers are 10-bit registers which specify the dead time value. The TSnDTC1A register is a mirror of the TSnDTC1 register for optimized DMA support.<br>These registers can be read/written with a 16-bit manipulation instruction.<br>Reset input sets these registers to 0000H.                                                                                                                           |  |  |  |  |  |  |  |
| Access        | These registers can be read/written in 16-bit units.                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |
| Address       | TS0DTC1: FFFFF58C <sub>H</sub> TS0DTC1A: FFFFFB42 <sub>H</sub><br>TS1DTC1: FFFFF5CC <sub>H</sub> TS1DTC1A: FFFFBC2 <sub>H</sub>                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |
| Initial Value | 0000 <sub>H</sub> . These registers are cleared by any reset.                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
|               | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |
| TSnDTC1/      | 0         0         0         0         0         Dead-time value 0         0                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
| TSnDTC1A      | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
| Note          | Throughout this manual the register name TSnDTC1 means also the register TSnDTC1A.                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |
| Caution       | <ol> <li>The dead time counter is enabled only in the PWM mode (TSnDSE of the<br/>TSnOPT0 register is set to 1), high-accuracy T-PWM mode, PWM mode<br/>with dead time, 120° excitation mode, special 120° excitation mode, and<br/>special pattern output mode (TSnDSE of the TSnOPT0 register is set to 1).<br/>In the other modes, be sure to set the TSnDTC1, or TSnDTC1A register<br/>respectively, register to 0000H.</li> </ol> |  |  |  |  |  |  |  |
|               | 2. Refer to <i>"Rewriting of TSnDTC0 and TSnDTC1 registers" on page 827</i><br>regardless of any operation mode of timer Sn when TSnDTC1, or<br>TSnDTC1A register respectively, is rewritten to another value during<br>operation of timer Sn (when TSnCE of TSnCTL0 register is set to 1).                                                                                                                                            |  |  |  |  |  |  |  |
|               | <ol> <li>Dead time is not inserted when the TSnDTC1 register, or TSnDTC1A<br/>register respectively, is set to 0000H.</li> </ol>                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |
|               | 4. Bits 15 to 10 and 0 are fixed to 0.                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |
|               |                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |



# 17.3 Control Register

# (1) Timer Sn control register 0 (TSnCTL0)

The TSnCTL0 register is an 8-bit register that controls the timer Sn operation.

Access This register can be read/written in 8-bit or 1-bit units.

| Address | TS0CTL0: | FFFFF580 <sub>H</sub> |  |  |
|---------|----------|-----------------------|--|--|
|         | TS1CTL0: | FFFF5C0 <sub>H</sub>  |  |  |

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|         | 7     | 6   | 5   | 4   | 3   | 2       | 1       | 0       |
|---------|-------|-----|-----|-----|-----|---------|---------|---------|
| TSnCTL0 | TSnCE | 0   | 0   | 0   | 0   | TSnCKS2 | TSnCKS1 | TSnCKS0 |
|         | R/W   | R/W | R/W | R/W | R/W | R/W     | R/W     | R/W     |

**Caution** Only the TSnCTL0.TSnCE bit may be changed during operation of timer Sn (when TSnCE is 1). Do not rewrite any other bit than the TSnCE bit.

## Table 17-2 TSnCTL0 register contents (1/2)

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|-----------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7               | TSnCE    | <ul> <li>Specifies the timer Sn operation.</li> <li>0: Count disabled (Reset timer Sn to asynchronous)</li> <li>1: Count clock operation enabled</li> <li>When setting the TSnCE bit to 0, the internal operation clock of timer Sn stops and resets timer Sn to asynchronous.</li> <li>When the TSnCE bit is set to 1, the internal operation of timer Sn is enabled and starts count-up operation. See <i>Table 17-3 on page 628</i>.</li> </ul>                                                                                         |  |  |  |  |  |
|                 |          | <ul> <li>Note: The functions initialized by TSnCE = 0 are as follows.</li> <li>Internal register and internal latch circuit except for register writable from CPU</li> <li>TSnOVF flag, flags of the TSnOPT6 register</li> <li>16-bit counter, 16-bit sub-counter, dead time counter, the TSnCNT register and TSnSBC register</li> <li>TSnCCR0 to TSnCCR5 buffer registers, TSnPAT0 buffer register, TSnPAT1 buffer register, TSnDTC0 buffer register and TSnDTC1 buffer register</li> <li>Timer output (inactive level output)</li> </ul> |  |  |  |  |  |



| Bit<br>position | Bit name           | Function                               |                             |                                                                      |                                             |       |  |  |
|-----------------|--------------------|----------------------------------------|-----------------------------|----------------------------------------------------------------------|---------------------------------------------|-------|--|--|
| 2 to 0          | TSnCKS2<br>TSnCKS1 | Selects the count clock of timer TMTn. |                             |                                                                      |                                             |       |  |  |
|                 | TSnCKS0            | TSnCKS2                                | TSnCKS1                     | TSnCKS0                                                              | Count Clock                                 |       |  |  |
|                 |                    | 0                                      | 0                           | 0                                                                    | PCLK0                                       |       |  |  |
|                 |                    | 0                                      | 0                           | 1                                                                    | PCLK1                                       |       |  |  |
|                 |                    | 0                                      | 1                           | 0                                                                    | PCLK2                                       |       |  |  |
|                 |                    |                                        | 0                           | 1                                                                    | 1                                           | PCLK3 |  |  |
|                 |                    | 1                                      | 0                           | 0                                                                    | PCLK4                                       |       |  |  |
|                 |                    | 1                                      | 0                           | 1                                                                    | PCLK5                                       |       |  |  |
|                 |                    | 1                                      | 1                           | 0                                                                    | PCLK7                                       |       |  |  |
|                 |                    | 1                                      | 1                           | 1                                                                    | PCLK9                                       |       |  |  |
|                 |                    | ⊤<br>⊤<br>2. ⊺<br>3. f⊧                | he TSnCKS[ź<br>SnCE is chai | 2:0] bits can b<br>nged from 0 t<br>2:0] bits are v<br>al I/O system | valid only when TSnCTL1.TSnEEE is set to 0. |       |  |  |

# Table 17-2 TSnCTL0 register contents (2/2)

# Table 17-3 Timer Sn Count Clock and Time from TSnCE = 1 Setting to Count-up Operation

| Count clock | TSnCKS2 | TSnCKS1 | TSnCKS0 | Min.          | Max.                             |  |
|-------------|---------|---------|---------|---------------|----------------------------------|--|
| PCLK0       | 0       | 0       | 0       | 4 base clocks | 5 base clocks                    |  |
| PCLK1       | 0       | 0       | 1       |               |                                  |  |
| PCLK2       | 0       | 1       | 0       |               |                                  |  |
| PCLK3       | 0       | 1       | 1       | 4 base clocks | 5 base clocks + 1 count<br>clock |  |
| PCLK4       | 1       | 0       | 0       |               |                                  |  |
| PCLK5       | 1       | 0       | 1       |               |                                  |  |
| PCLK7       | 1       | 1       | 0       |               |                                  |  |
| PCLK9       | 1       | 1       | 1       | ]             |                                  |  |

Note Base clock: fTMSn



| (2)           | Timer Sn control register 1 (TSnCTL1)                                           |                                                                  |        |     |        |        |        |        |  |  |
|---------------|---------------------------------------------------------------------------------|------------------------------------------------------------------|--------|-----|--------|--------|--------|--------|--|--|
|               | The TSnCTL1 register is an 8-bit register that controls the timer Sn operation. |                                                                  |        |     |        |        |        |        |  |  |
| Access        | This regis                                                                      | This register can be read/written in 8-bit or 1-bit units.       |        |     |        |        |        |        |  |  |
| Address       |                                                                                 | TS0CTL1: FFFFF581 <sub>H</sub><br>TS1CTL1: FFFFF5C1 <sub>H</sub> |        |     |        |        |        |        |  |  |
| Initial Value | 00 <sub>H</sub> . This register is cleared by any reset.                        |                                                                  |        |     |        |        |        |        |  |  |
|               | 7                                                                               | 6                                                                | 5      | 4   | 3      | 2      | 1      | 0      |  |  |
| TSnCTL1       | 0                                                                               | TSnEST                                                           | TSnEEE | 0   | TSnMD3 | TSnMD2 | TSnMD1 | TSnMD0 |  |  |
|               | R/W                                                                             | R/W                                                              | R/W    | R/W | R/W    | R/W    | R/W    | R/W    |  |  |

**Caution** 1. Only TSnEST bit can be changed during the timer Sn operation (when TSnCTL0.TSnCE is 1). Do not rewrite any other bit than the TSnEST bit. However, write access of the same value is possible.

2. The default value 0 of bits 4 and 7 must not changed.

# Table 17-4 TSnCTL1 register contents (1/2)

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|-----------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 6               | TSnEST   | <ul> <li>Sets to enable/disable software trigger control.</li> <li>0: Disables software trigger control.</li> <li>1: Enables software trigger control.</li> <li>In one-shot pulse mode.<br/>(One-shot pulse software trigger)</li> <li>In external trigger pulse output mode<br/>(Pulse output software trigger)</li> </ul>                                  |  |  |  |  |  |  |
|                 |          | <ul> <li>Caution: The function operates as a software trigger by setting TSnEST to 1 during the timer Sn operation (when the value of TSnCE of TSnCTL0 register is 1). The function operates as a software trigger by setting TSnCE = 1 when the value of TSnEST is 1 while TSnCE = 0.</li> <li>Note: The TSnEST bit is always read as "0".</li> </ul>       |  |  |  |  |  |  |
| 5               | TSnEEE   | Specifies count clock.<br>0: Use the clock selected with the TSnCKS2 to TSnCKS0 bits.<br>1: Use the external clock (TEVTSn pin input edge).<br>The valid edge during TSnEEE = 1 (external clock: TEVTSn pin) is specified with the<br>TSnEES1 and TSnEES0 bits of the TSnIOC2 register.<br>Note: The TSnEEE bit is ignored in the external event count mode. |  |  |  |  |  |  |



| Bit<br>position | Bit name         | Function               |            |          |        |                                    |            |  |  |
|-----------------|------------------|------------------------|------------|----------|--------|------------------------------------|------------|--|--|
| 3 to 0          | TSnMD3<br>TSnMD2 | Selects the timer mode |            |          |        |                                    |            |  |  |
|                 | TSnMD1           | -                      | TSnMD3     | TSnMD2   | TSnMD1 | TSnMD0                             | Timer Mode |  |  |
|                 | TSnMD0           | 0                      | 0          | 0        | 0      | Interval timer mode                |            |  |  |
|                 |                  | 0                      | 0          | 0        | 1      | External event count mode          |            |  |  |
|                 |                  | 0                      | 0          | 1        | 0      | External trigger pulse output mode |            |  |  |
|                 |                  | 0                      | 0          | 1        | 1      | One-shot pulse mode                |            |  |  |
|                 |                  | 0                      | 1          | 0        | 0      | PWM mode                           |            |  |  |
|                 |                  | 0                      | 1          | 0        | 1      | Free-running mode                  |            |  |  |
|                 |                  | 0                      | 1          | 1        | 1      | Triangular-wave PWM mode           |            |  |  |
|                 |                  | 1                      | 0          | 0        | 0      | High-accuracy T-PWM mode           |            |  |  |
|                 |                  | 1                      | 0          | 0        | 1      | PWM mode with dead time            |            |  |  |
|                 |                  | 1                      | 0          | 1        | 0      | 120° excitation mode               |            |  |  |
|                 |                  | 1                      | 0          | 1        | 1      | Special 120° excitation mode       |            |  |  |
|                 |                  | 1                      | 1          | 0        | 0      | Special pattern output mode        |            |  |  |
|                 |                  |                        | Other that | an above |        | Setting prohibited                 |            |  |  |

# Table 17-4 TSnCTL1 register contents (2/2)



#### (3) Timer Sn I/O control register 0 (TSnIOC0)

The TSnIOC0 register is a 16-bit register that controls the timer output (TOSn0 to TOSn7 pins).

- Access This register can be read/written in 16-bit or 8-bit units. However, use the TSnIOC0 register for 16-bit access only. TSnIOC0H enables access to the higher 8 bits of the TSnIOC0 register and TSnIOC0L enables access to the lower 8 bits of the TSnIOC0 register.
- Address TS0IOC0: FFFFF582<sub>H</sub> TS0IOC0H: FFFFF583<sub>H</sub> TS0IOC0L: FFFFF582<sub>H</sub> TS1IOC0: FFFFF5C2<sub>H</sub> TS1IOC0H: FFFFF5C3<sub>H</sub> TS1IOC0L: FFFFF5C2<sub>H</sub>

| nitial Value | 0000µ. | This register is | cleared by | any reset. |
|--------------|--------|------------------|------------|------------|
|              |        |                  |            |            |

|          | 15     | 14     | 13     | 12     | 11     | 10     | 9      | 8      |
|----------|--------|--------|--------|--------|--------|--------|--------|--------|
| TSnIOC0  | TSnOL7 | TSnOE7 | TSnOL6 | TSnOE6 | TSnOL5 | TSnOE5 | TSnOL4 | TSnOE4 |
|          | R/W    |
|          |        |        |        |        |        |        |        |        |
|          | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|          | TSnOL3 | TSnOE3 | TSnOL2 | TSnOE2 | TSnOL1 | TSnOE1 | TSnOL0 | TSnOE0 |
|          | R/W    |
|          |        |        |        |        |        |        |        |        |
|          | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| TSnIOC0H | TSnOL7 | TSnOE7 | TSnOL6 | TSnOE6 | TSnOL5 | TSnOE5 | TSnOL4 | TSnOE4 |
|          | R/W    |
|          |        |        |        |        |        |        |        |        |
|          | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| TSnIOC0L | TSnOL3 | TSnOE3 | TSnOL2 | TSnOE2 | TSnOL1 | TSnOE1 | TSnOL0 | TSnOE0 |
|          | R/W    |
|          |        |        |        |        |        |        |        |        |

**Caution 1.** Set the TSnIOC0 register when TSnCTL0.TSnCE is set to 0, in order to prevent the case that dead time cannot be secured, or short pulse is generated on output pins. Write access of the same value is possible for the TSnIOC0 register during timer Sn operation (when TSnCTL0.TSnCE is set to 1).

 If the TSnOL1 to TSnOL6 bits are changed while the TSnIOC4.TSnTBA[2:0] bits and the TSnIOC4.TSnEOC bit is set to 1, an error interrupt may be generated accidentally. To stop the timer output during timer operation or to change the output level forcibly, it is recommended to set the operating mode of timer ouput pins TOSn0 to TOSn7 to port mode, rather than manipulating the TSnIOC0 register.



| Bit position | Bit name | Function                                                                                                                                    |
|--------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------|
| 15           | TSnOL7   | Sets the TOSn7 pin output level.<br>0: Active level is high level.<br>1: Active level is low level.                                         |
| 14           | TSnOE7   | Enables/disables the TOSn7 pin output.<br>0: Timer output disabled (Output is inactive level of TSnOL7.)<br>1: Timer output enabled         |
| 13           | TSnOL6   | Sets the TOSn6 pin output level.<br>0: Active level is high level.<br>1: Active level is low level.                                         |
| 12           | TSnOE6   | Enables/disables the TOSn6 pin output.<br>0: Timer output disabled (Output is inactive level of TSnOL6 bit).<br>1: Timer output enabled     |
| 11           | TSnOL5   | Sets the TOSn5 pin output level.<br>0: Active level is high level.<br>1: Active level is low level.                                         |
| 10           | TSnOE5   | Enables/disables the TOSn5 pin output.<br>0: Timer output disabled (Output is inactive level of TSnOL5 bit).<br>1: Timer output enabled     |
| 9            | TSnOL4   | Sets the TOSn4 pin output level.<br>0: Active level is high level.<br>1: Active level is low level.                                         |
| 8            | TSnOE4   | Enables/disables the TOSn4 pin output.<br>0: Timer output disabled (Output is inactive level of TSnOL4 bit).<br>1: Timer output enabled     |
| 7            | TSnOL3   | Sets the TOSn3 pin output level.<br>0: Active level is high level.<br>1: Active level is low level.                                         |
| 6            | TSnOE3   | Enables/disables the TOSn3 pin output.<br>0: Timer output disabled (Output is inactive level of TSnOL3 bit).<br>1: Timer output enabled     |
| 5            | TSnOL2   | Sets the TOSn2 pin output level.<br>0: Active level is high level.<br>1: Active level is low level.                                         |
| 4            | TSnOE2   | Enables/disables the TOSn2 pin output.<br>0: Timer output disabled (Output is inactive level of the TSnOL2 bit)<br>1: Timer output enabled  |
| 3            | TSnOL1   | Sets the TOSn1 output level.<br>0: Active level is high level.<br>1: Active level is low level.                                             |
| 2            | TSnOE1   | Enables/disables the TOSn1 pin output.<br>0: Timer output disabled (Output is inactive level of the TSnOL1 bit).<br>1: Timer output enabled |
| 1            | TSnOL0   | Sets the TOSn0 output level.<br>0: Active level is high level.<br>1: Active level is low level.                                             |
| 0            | TSnOE0   | Enables/disables the TOSn0 pin output.<br>0: Timer output disabled (Output is inactive level of the TSnOL0 bit).<br>1: Timer output enabled |



## (4) Timer Sn I/O control register 2 (TSnIOC2)

The TSnIOC2 register is an 8-bit register that controls the valid edge for the external event count input (TEVTSn pin) and external trigger input (TTRGSn pin).

Access This register can be read/written in 8-bit or 1-bit units.

Address TS0IOC2: FFFF584<sub>H</sub> TS1IOC2: FFFF5C4<sub>H</sub>

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|         | 7 | 6 | 5 | 4 | 3       | 2       | 1       | 0       |
|---------|---|---|---|---|---------|---------|---------|---------|
| TSnIOC2 | 0 | 0 | 0 | 0 | TSnEES1 | TSnEES0 | TSnETS1 | TSnETS0 |
|         | R | R | R | R | R/W     | R/W     | R/W     | R/W     |

**Caution** Set the TSnIOC2 register while operation of timer Sn is stopped (when the value of TSnCTL0.TSnCE is 0). Write access of the same value is possible for the TSnIOC2 register during the timer Sn operation (TSnCTL0.TSnCE is set to 1).

## Table 17-6 TTnIOC2 register contents

| Bit<br>position | Bit name           | Function                                                                                                                                                                    |              |                                                                                                                                    |  |  |
|-----------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 3, 2            | TSnEES1<br>TSnEES0 | Specifies th                                                                                                                                                                | e external e | event counter input (TEVTSn) valid edge.                                                                                           |  |  |
|                 |                    | TSnEES1                                                                                                                                                                     | TTnEES0      | External event counter input (TEVTTn) valid edge setting                                                                           |  |  |
|                 |                    | 0                                                                                                                                                                           | 0            | No edge detection (Trigger is masked.)                                                                                             |  |  |
|                 |                    | 0                                                                                                                                                                           | 1            | Rising edge detection                                                                                                              |  |  |
|                 |                    | 1                                                                                                                                                                           | 0            | Falling edge detection                                                                                                             |  |  |
|                 |                    | 1                                                                                                                                                                           | 1            | Both, rising and falling edge detection                                                                                            |  |  |
|                 | TO 5704            | Note: The TSnEES1 and TSnEES0 bits are valid only when TSnCTL1.TSnEEE bit<br>is set to 1, or when the external event count mode is selected<br>(TSnCTL1.TSnMD[3:0] = 0001B) |              |                                                                                                                                    |  |  |
| 1, 0            | TSnETS1<br>TSnETS0 | Specifies the external trigger input (TTRGSn) valid edge.                                                                                                                   |              |                                                                                                                                    |  |  |
|                 |                    | TSnETS1                                                                                                                                                                     | TSnETS0      | External trigger input (TTRGSn) valid edge setting                                                                                 |  |  |
|                 |                    | 0                                                                                                                                                                           | 0            | No edge detection (Trigger is masked.)                                                                                             |  |  |
|                 |                    | 0                                                                                                                                                                           | 1            | Rising edge detection                                                                                                              |  |  |
|                 |                    | 1                                                                                                                                                                           | 0            | Falling edge detection                                                                                                             |  |  |
|                 |                    | 1                                                                                                                                                                           | 1            | Both, rising and falling edge detection                                                                                            |  |  |
|                 |                    | puls                                                                                                                                                                        | se output m  | and TSnETS0 bits are valid only when the external trigger<br>ode, or one-shot pulse mode is selected<br>MD[3:0] = 0010B, or 0011B) |  |  |



| (5)           | Timer Sn               | Timer Sn I/O control register 4 (TSnIOC4)                                                   |             |                |         |               |     |        |
|---------------|------------------------|---------------------------------------------------------------------------------------------|-------------|----------------|---------|---------------|-----|--------|
|               |                        | The TSnIOC4 register is an 8-bit register that controls timer output (TOSn1 to TOSn6 pins). |             |                |         |               |     |        |
| Access        | This regis             | ster can be                                                                                 | e read/writ | ten in 8-bit ( | or 1-bi | t units.      |     |        |
| Address       |                        | TS0IOC4: FFFF585 <sub>H</sub><br>TS1IOC4: FFFF5C5 <sub>H</sub>                              |             |                |         |               |     |        |
| Initial Value | 00 <sub>H</sub> . This | register is                                                                                 | cleared b   | by any reset   | -       |               |     |        |
|               | 7                      | 6                                                                                           | 5           | 4              | 3       | 2             | 1   | 0      |
| TSnIOC4       | 0                      | TSnTBA2                                                                                     | TSnTBA1     | TSnTBA0        | 0       | TSnWOC        | 0   | TSnEOC |
|               | R                      | R/W                                                                                         | R/W         | R/W            | R       | R/W           | R   | R/W    |
| Caution       |                        | SnIOC4 re<br>0.TSnCE i                                                                      | •           | •              | of tim  | er Sn is stop | ped |        |

# Table 17-7 TSnIOC4 register contents (1/2)

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|-----------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 6               | TSnTBA2  | <ul> <li>Selects whether to detect the simultaneous active states of the TOSn5 and TOSn6 pins.</li> <li>0: Don't detect the simultaneous active states of the TOSn5 and TOSn6 pins.</li> <li>1: Detect the simultaneous active states of the TOSn5 and TOSn6 pins.</li> <li>Note: If simultaneous active states are detected while TSnEOC = 1 or TSnTBA2 = 1, the positive/negative phase simultaneous active state detection flag (TSnTBF) is set to 1 and an error interrupt (INTTSnER) occurs.</li> </ul>                                                        |  |  |  |  |
| 5               | TSnTBA1  | Selects whether to detect the simultaneous active states of the TOSn3 and TOSn4 pins.         0: Don't detect the simultaneous active states of the TOSn3 and TOSn4 pins.         1: Detect the simultaneous active states of the TOSn3 and TOSn4 pins.         1: Detect the simultaneous active states of the TOSn3 and TOSn4 pins.         Note:       If simultaneous active states are detected while TSnEOC = 1 or TSnTBA1 = 1, the positive/negative phase simultaneous active detection flag (TSnTBF) is set to 1 and an error interrupt (INTTSnER) occurs. |  |  |  |  |
| 4               | TSnTBA0  | Selects whether to detect the simultaneous active states of the TOSn1 and TOSn2 pins.         0: Don't detect the simultaneous active states of the TOSn1 and TOSn2 pins.         1: Detect the simultaneous active states of the TOSn1 and TOSn2 pins.         Note:       If simultaneous active states are detected while TSnEOC = 1 or TSnTBA0 = 1, the positive/negative phase simultaneous active detection flag (TSnTBF) is set to 1 and an error interrupt (INTTSnER) occurs.                                                                               |  |  |  |  |
| 2               | TSnWOC   | <ul> <li>Selects the warning detection during motor control.</li> <li>0: Disable the warning interrupt (INTTSnWN)</li> <li>1: Enable the warning interrupt (INTTSnWN)</li> <li>Note: Refer to <i>"Warning interrupt function" on page 755</i> for details on warning interrupt control.</li> </ul>                                                                                                                                                                                                                                                                  |  |  |  |  |

RENESAS

| Bit<br>position | Bit name | Function                                                                                                                                            |  |  |  |  |
|-----------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 0               | TSnEOC   | Selects the error status detection during motor control.<br>0: Disable the error interrupt (INTTSnER).<br>1: Enable the error interrupt (INTTSnER). |  |  |  |  |
|                 |          | <b>Note:</b> Refer to <i>"Error interrupt function" on page 752</i> for details on error interrupt control.                                         |  |  |  |  |



## (6) Timer Sn option register 0 (TSnOPT0)

The TSnOPT0 register is an 8-bit register that detects overflow. This register can be read/written with an 8-bit or 1-bit manipulation instruction. Reset input sets this register to 00H.

Access This register can be read/written in 8-bit or 1-bit units.

Address TS0OPT0: FFFFF586<sub>H</sub> TS1IOPT0: FFFFF5C6<sub>H</sub>

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|         | 7 | 6 | 5 | 4 | 3      | 2      | 1      | 0      |
|---------|---|---|---|---|--------|--------|--------|--------|
| TSnOPT0 | 0 | 0 | 0 | 0 | TSnDSE | TSnCMS | TSnCUF | TSnOVF |
|         | R | R | R | R | R/W    | R/W    | R/W    | R/W    |

**Caution** Do not rewrite the TSnDSE bit of the TSnOPT0 register during the timer Sn operation (when TSnCTL0.TSnCE is set to 1). However, write access of the same value is possible.

#### Table 17-8 TSnOPT0 register contents (1/2)

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3               | TSnDSE   | <ul> <li>Enables/disables dead time control in the PWM mode and in the special pattern output mode.</li> <li>0: Disables dead time control</li> <li>1: Enables dead time control</li> <li>Note: The TSnDSE bit is valid only in PWM mode and in special pattern output mode, but is invalid in the other modes.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2               | TSnCMS   | <ul> <li>Specifies the transfer timing of the compare register in the high-accuracy T-PWM mode.</li> <li>0: Reload mode (batch rewrite function)<br/>When writing to the TSnCCR1 register, reload is enabled and then the value is updated (reloaded) simultaneously at the next reload timing. Reload is not enabled even if written to a register other than TSnCCR1.</li> <li>1: Anytime rewrite mode<br/>Writing to each compare register under update operation by each independent compare register enables write access value updating anytime. 4 clocks are needed from register write until the value is transferred. In the case of the TSnCCR1 register, 5 clocks are needed.</li> <li>Caution: Set TSnCMS to 0 in any mode other than the high-accuracy T-PWM mode because the transfer timing is fixed.</li> </ul> |
| 1               | TSnCUF   | <ul> <li>This is a flag indicating the 16-bit counter count status.</li> <li>0: 16-bit counter is in count up status.</li> <li>1: 16-bit counter is in count down status.</li> <li>Note: The TSnCUF bit is valid only in the high-accuracy T-PWM mode and in the triangular-wave PWM mode, but is invalid (TSnCUF = 0) in any other mode.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

RENESAS

# Table 17-8 TSnOPT0 register contents (2/2)

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|-----------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|                 |          | This is a flag indicating the timer Sn overflow.<br>It is set to 1 when the 16-bit counter value overflows from FFFFH to 0000H. This flag<br>is cleared by writing 0 or setting TSnCE to 0. An overflow interrupt (INTTSnOV)<br>occurs at the same time that the TSnOVF bit is set to 1. |  |  |  |  |  |
| 0               | TSnOVF   | <ul> <li>Caution: 1. Overflow occurs only in the free-running mode or high-accuracy T-<br/>PWM mode. In the high-accuracy T-PWM mode, the TSnOVF bit may<br/>be set to 1 if the setting value condition of the TSnDTC0 and<br/>TSnDTC1 registers is incorrect.</li> </ul>                |  |  |  |  |  |
|                 |          | <ol> <li>The TSnOVF bit is not cleared even if the TSnOVF bit and the<br/>TSnOPT0 register are read while TSnOVF = 1.</li> </ol>                                                                                                                                                         |  |  |  |  |  |
|                 |          | <ol> <li>Reading or writing is possible for the TSnOVF bit, but writing 1 to the<br/>TSnOVF bit is ignored.</li> </ol>                                                                                                                                                                   |  |  |  |  |  |
|                 |          |                                                                                                                                                                                                                                                                                          |  |  |  |  |  |



## (7) Timer Sn option registers 1, 1H, 1L (TSnOPT1, TSnOPT1H, TSnOPT1L) Timer Sn option registers 1A, 1AH, 1AL (TSnOPT1A, TSnOPT1AH, TSnOPT1AL)

The TSnOPT1 and TSnOPT1A registers are 16-bit registers which enable/disable peak/trough interrupt and set the interrupt thinning out ratio. The TSnOPT1A register is a mirror of the TSnOPT1 register for optimized DMA support.

Access These registers can be read/written with a 16-bit, 8-bit, or 1-bit manipulation instruction.

TSnOPT1H, and TSnOPT1AH respectively, is an 8-bit register, which can access the higher 8 bits of the TSnOPT1 register, and TSnOPT1A register respectively. TSnOPT1L, and TSnOPT1AL respectively, is an 8-bit register, which can access the lower 8 bits of the TSnOPT1 register, and TSnOPT1AL respectively

- Initial Value 0000<sub>H</sub>. These registers are cleared by any reset.

|           | 15                                                                                                                                                                                                                                                     | 14          | 13          | 12      | 11        | 10        | 9         | 8       |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------|---------|-----------|-----------|-----------|---------|
| TSnOPT1/  | 0                                                                                                                                                                                                                                                      | 0           | 0           | 0       | 0         | 0         | TSnRTE    | TSnRBE  |
| TSnOPT1A  | R                                                                                                                                                                                                                                                      | R           | R           | R       | R         | R         | R/W       | R/W     |
|           | 7                                                                                                                                                                                                                                                      | 6           | 5           | 4       | 3         | 2         | 1         | 0       |
|           | TSnICE                                                                                                                                                                                                                                                 | TSnIOE      | TSnRDE      | TSnID4  | TSnID3    | TSnID2    | TSnID1    | TSnID0  |
|           | R/W                                                                                                                                                                                                                                                    | R/W         | R/W         | R/W     | R/W       | R/W       | R/W       | R/W     |
|           |                                                                                                                                                                                                                                                        |             |             |         |           |           |           |         |
|           | 7                                                                                                                                                                                                                                                      | 6           | 5           | 4       | 3         | 2         | 1         | 0       |
| TSnOPT1H/ | 0                                                                                                                                                                                                                                                      | 0           | 0           | 0       | 0         | 0         | TSnRTE    | TSnRBE  |
| TSnOPT1AH | R                                                                                                                                                                                                                                                      | R           | R           | R       | R         | R         | R/W       | R/W     |
|           |                                                                                                                                                                                                                                                        |             |             |         |           |           |           |         |
|           | 7                                                                                                                                                                                                                                                      | 6           | 5           | 4       | 3         | 2         | 1         | 0       |
| TSnOPT1L/ | TSnICE                                                                                                                                                                                                                                                 | TSnIOE      | TSnRDE      | TSnID4  | TSnID3    | TSnID2    | TSnID1    | TSnID0  |
| TSnOPT1AL | R/W                                                                                                                                                                                                                                                    | R/W         | R/W         | R/W     | R/W       | R/W       | R/W       | R/W     |
|           |                                                                                                                                                                                                                                                        |             |             |         |           |           |           |         |
| Caution   | The register rewriting methods for the TSnOPT1, TSnOPT1H, TSnOPT1L, TSnOPT1A, TSnOPT1AH, and TSnOPT1AL registers during count operation in the high-accuracy T-PWM mode are as follows based on the setting of the TSnCMS bit of the TSnOPT0 register. |             |             |         |           |           |           |         |
|           | <ul> <li>TSnCMS = 0: Reload rewriting</li> <li>TSnCMS = 1: Anytime rewriting</li> </ul>                                                                                                                                                                |             |             |         |           |           |           |         |
|           |                                                                                                                                                                                                                                                        |             | •           | •       |           |           |           |         |
|           | The reload<br>PWM modes<br>excitation                                                                                                                                                                                                                  | de, triangu | ılar-wave l | PWM mod | de, PWM r | node with | dead time | e, 120° |

mode.

RENESAS

| Table 17-9 | TSnOPT1/TSnOPT1A register contents (1/2) |
|------------|------------------------------------------|
|------------|------------------------------------------|

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                  |
|-----------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9               | TSnRTE   | Enables/disables reload at the peak reload timing.<br>0: Disables the reload operation at the peak timing of 16-bit counter.<br>1: Enables the reload operation at the peak timing of 16-bit counter.                                                                                                                                                     |
|                 |          | <b>Note:</b> The TSnRTE bit is valid only in the external trigger pulse output mode, PWM mode, high-accuracy T-PWM mode, PWM mode with dead time, 120° excitation mode, special 120° excitation mode, and special pattern output mode.                                                                                                                    |
| 8               | TSnRBE   | Enables/disables reload at the trough reload timing.<br>0: Disables reload operation at the trough timing for 16-bit counter.<br>1: Enables reload operation at the trough timing for 16-bit counter.                                                                                                                                                     |
|                 |          | <b>Note:</b> The TSnRBE bit is valid only in the high-accuracy T-PWM mode and triangular-wave PWM mode.                                                                                                                                                                                                                                                   |
| 7               | TSnICE   | <ul> <li>Enables/disables occurrence of the peak interrupt (INTTSnCD0).</li> <li>0: Disables the peak interrupt (INTTSnCD0) at the peak timing for 16-bit counter.<br/>Not subject to interrupt thinning out.</li> <li>1: Enables the peak interrupt (INTTSnCD0) at the peak timing for 16-bit counter.<br/>Subject to interrupt thinning out.</li> </ul> |
|                 |          | Note: The TSnICE bit is valid only in the PWM mode, high-accuracy T-PWM mode, PWM mode with dead time, 120° excitation mode, special 120° excitation mode, and special pattern output mode.                                                                                                                                                               |
| 6               | TSnIOE   | Enables/disables occurrence of the trough interrupt (INTTSnOD).<br>0: Disables the trough interrupt.<br>Not subject to interrupt thinning out.                                                                                                                                                                                                            |
|                 |          | Note: 1:Enables the trough interrupt.<br>Subject to interrupt thinning out.                                                                                                                                                                                                                                                                               |
|                 |          | The TSnIOE bit is valid only in high-accuracy T-PWM mode and triangular-wave PWM output mode.                                                                                                                                                                                                                                                             |
| 5               | TSnRDE   | <ul> <li>Enables/disables thinning out at the reload timing.</li> <li>0: No reload thinning out<br/>Reload timing is generated based on the setting of the TSnRTE and TSnRBE<br/>bits.</li> <li>1: Reload thinning out provided<br/>Reload timing is generated in the same interval as interrupt thinning out.</li> </ul>                                 |
|                 |          | <b>Note:</b> The TSnRDE bit is valid only in the PWM mode, high-accuracy T-PWM mode, triangular-wave PWM mode, PWM mode with dead time, 120° excitation mode, special 120° excitation mode, and special pattern output mode. The TSnRDE bit must be set to 1 in any mode other than the above.                                                            |



| Bit<br>position | Bit name   |                             | Function                                                                                                                 |                                                                                                               |                                                                                             |                                                                             |                                                                                                                                                                                                                                                     |  |
|-----------------|------------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 4 to 0          | TSnID[4:0] | Specifies th                | Specifies the thinning out ratio of interrupts (INTTSnCD0, INTTSnOD).                                                    |                                                                                                               |                                                                                             |                                                                             |                                                                                                                                                                                                                                                     |  |
|                 |            | TSnID4                      | TSnID3                                                                                                                   | TSnID2                                                                                                        | TSnID1                                                                                      | TSnID0                                                                      | Thinning out Ratio                                                                                                                                                                                                                                  |  |
|                 |            | 0                           | 0                                                                                                                        | 0                                                                                                             | 0                                                                                           | 0                                                                           | No thinning out                                                                                                                                                                                                                                     |  |
|                 |            | 0                           | 0                                                                                                                        | 0                                                                                                             | 0                                                                                           | 1                                                                           | 1/2                                                                                                                                                                                                                                                 |  |
|                 |            | 0                           | 0                                                                                                                        | 0                                                                                                             | 1                                                                                           | 0                                                                           | 1/3                                                                                                                                                                                                                                                 |  |
|                 |            | 0                           | 0                                                                                                                        | 0                                                                                                             | 1                                                                                           | 1                                                                           | 1/4                                                                                                                                                                                                                                                 |  |
|                 |            | •                           | •                                                                                                                        |                                                                                                               |                                                                                             |                                                                             |                                                                                                                                                                                                                                                     |  |
|                 |            |                             |                                                                                                                          |                                                                                                               |                                                                                             |                                                                             |                                                                                                                                                                                                                                                     |  |
|                 |            | 1                           | . 1                                                                                                                      | 1                                                                                                             | 0                                                                                           | . 1                                                                         | 1/30                                                                                                                                                                                                                                                |  |
|                 |            | 1                           | 1                                                                                                                        | 1                                                                                                             | 1                                                                                           | 0                                                                           | 1/31                                                                                                                                                                                                                                                |  |
|                 |            | 1                           | 1                                                                                                                        | 1                                                                                                             | 1                                                                                           | 1                                                                           | 1/32                                                                                                                                                                                                                                                |  |
|                 |            | PW<br>exc<br>mo<br>Caution: | /M mode, tri<br>itation mode<br>de.<br>During the<br>thinning out<br>and TSnOF<br>respectively<br>bits).<br>The interrup | angular-wa<br>e, special 12<br>timer Sn op<br>t counter is o<br>2T1L registe<br>r (including<br>ot thinning c | ve PWM mo<br>20° excitation<br>eration (which<br>cleared if wi<br>ers, TSnOP<br>when the sa | en TSnCTL(<br>rite access is<br>T1A and TS<br>ame value is<br>is not cleare | WM mode, high-accuracy T-<br>node with dead time, 120°<br>d special pattern output<br>D.TSnCE = 1), the interrupt<br>s executed to the TSnOPT1<br>nOPT1AL registers<br>s written to the TSnID[4:0]<br>ed by write access of the<br>er respectively. |  |

# Table 17-9 TSnOPT1/TSnOPT1A register contents (2/2)

 Table 17-10
 Reload, peak interrupt and trough interrupt (1/3)

| Mode                             | TSnC<br>MS | TSnR<br>DE | TSnl<br>CE | TSnR<br>TE | TSnl<br>OE | TSnR<br>BE | Reload                 | INTTSnCD0            | INTTSnOD |
|----------------------------------|------------|------------|------------|------------|------------|------------|------------------------|----------------------|----------|
| PWM mode,<br>PWM mode with       | 1          | х          | x          | x          | х          | x          | Setting prohibited     |                      |          |
| dead time,<br>120° excitation    | 0          | 0          | х          | 0          | х          | х          | No                     |                      |          |
| mode,<br>special 120°            | 0          | 0          | x          | 1          | x          | x          | Peak                   | Occurrence<br>Note 1 |          |
| excitation mode, special pattern | 0          | 1          | 0          | 0          | х          | х          | No                     |                      |          |
| output mode                      | 0          | 1          | 0          | 1          | х          | х          | No                     |                      |          |
|                                  | 0          | 1          | 1          | 0          | х          | х          | No                     |                      |          |
|                                  | 0          | 1          | 1          | 1          | х          | х          | Peak <sup>Note 3</sup> | Occurrence           | -        |



| Mode                         | TSnC<br>MS | TSnR<br>DE | TSnl<br>CE | TSnR<br>TE | TSnI<br>OE | TSnR<br>BE | Reload                                                         | INTTSnCD0            | INTTSnOD             |
|------------------------------|------------|------------|------------|------------|------------|------------|----------------------------------------------------------------|----------------------|----------------------|
| Triangular-wave<br>PWM mode  | 1          | x          | х          | x          | x          | x          | Setting prohibited                                             |                      |                      |
|                              | 0          | 0          | х          | х          | х          | 0          | No                                                             |                      |                      |
|                              | 0          | 0          | х          | x          | x          | 1          | Trough                                                         | -                    | Occurrence<br>Note 2 |
|                              | 0          | 1          | х          | х          | 0          | 0          | No                                                             |                      |                      |
|                              | 0          | 1          | х          | х          | 0          | 1          | No                                                             |                      |                      |
|                              | 0          | 1          | х          | х          | 1          | 0          | No                                                             |                      |                      |
|                              | 0          | 1          | х          | х          | 1          | 1          | Trough <sup>Note 3</sup>                                       | -                    | Occurrence           |
| High-accuracy T-<br>PWM mode | 1          | х          | х          | x          | х          | x          | Anytime                                                        | Occurrence<br>Note 1 | Occurrence<br>Note 2 |
|                              | 0          | 0          | х          | 0          | х          | 0          | No                                                             |                      |                      |
|                              | 0          | 0          | х          | 0          | х          | 1          | Trough                                                         | Occurrence<br>Note 1 | Occurrence<br>Note 2 |
|                              | 0          | 0          | х          | 1          | x          | 0          | Peak                                                           | Occurrence<br>Note 1 | Occurrence<br>Note 2 |
|                              | 0          | 0          | x          | 1          | x          | 1          | Peak/trough                                                    | Occurrence<br>Note 1 | Occurrence<br>Note 2 |
|                              | 0          | 1          | 0          | 0          | 0          | 0          | No                                                             |                      |                      |
|                              | 0          | 1          | 0          | 0          | 0          | 1          | No                                                             |                      |                      |
|                              | 0          | 1          | 0          | 0          | 1          | 0          | No                                                             |                      |                      |
|                              | 0          | 1          | 0          | 0          | 1          | 1          | Trough <sup>Note 3</sup>                                       | -                    | Occurrence           |
|                              | 0          | 1          | 0          | 1          | 0          | 0          | No                                                             |                      |                      |
|                              | 0          | 1          | 0          | 1          | 0          | 1          | No                                                             |                      |                      |
|                              | 0          | 1          | 0          | 1          | 1          | 0          | No                                                             |                      |                      |
|                              | 0          | 1          | 0          | 1          | 1          | 1          | Trough <sup>Note 3</sup>                                       | -                    | Occurrence           |
|                              | 0          | 1          | 1          | 0          | 0          | 0          | No                                                             |                      |                      |
|                              | 0          | 1          | 1          | 0          | 0          | 1          | No                                                             |                      |                      |
|                              | 0          | 1          | 1          | 0          | 1          | 0          | No                                                             |                      |                      |
|                              | 0          | 1          | 1          | 0          | 1          | 1          | Trough <sup>Note 3</sup>                                       | Occurrence           | Occurrence           |
|                              | 0          | 1          | 1          | 1          | 0          | 0          | Peak <sup>Note 3</sup>                                         | Occurrence           | -                    |
|                              | 0          | 1          | 1          | 1          | 0          | 1          | Peak <sup>Note 3</sup>                                         | Occurrence           | -                    |
|                              | 0          | 1          | 1          | 1          | 1          | 0          | Peak <sup>Note 3</sup>                                         | Occurrence           | Occurrence           |
|                              | 0          | 1          | 1          | 1          | 1          | 1          | Peak <sup>Note</sup><br><sup>3</sup> /Trough <sup>Note 3</sup> | Occurrence           | Occurrence           |

# Table 17-10Reload, peak interrupt and trough interrupt (2/3)



| Mode                               | TSnC<br>MS | TSnR<br>DE | TSnl<br>CE | TSnR<br>TE | TSnl<br>OE | TSnR<br>BE | Reload                | INTTSnCD0 | INTTSnOD |
|------------------------------------|------------|------------|------------|------------|------------|------------|-----------------------|-----------|----------|
| External trigger pulse output mode | 1          | х          | х          | х          | х          | x          | Setting prohibited    |           |          |
|                                    | 0          | 0          | х          | 0          | х          | х          | No                    |           |          |
|                                    | 0          | 0          | х          | 1          | х          | х          | Peak                  | -         | -        |
|                                    | 0          | 1          | 0          | 0          | х          | x          | Setting prohibited    |           |          |
|                                    | 0          | 1          | 0          | 1          | х          | x          | Setting<br>prohibited |           |          |
|                                    | 0          | 1          | 1          | 0          | х          | x          | Setting prohibited    |           |          |
|                                    | 0          | 1          | 1          | 1          | х          | x          | Setting prohibited    |           |          |

Table 17-10Reload, peak interrupt and trough interrupt (3/3)

Note 1. Only when TSnICE = 1

- **2.** Only when TSnIOE = 1
- 3. At the timing at which thinning out of the peak interrupt or the trough interrupt does not occur.
- 4. X: 0 or 1
- 5. Throughout this manual the register name TSnOPT1(H/L) means also the register TSnOPT1A(H/L).



(8) Timer Sn option registers 2, 2H, 2L (TSnOPT2, TSnOPT2H, TSnOPT2L) These TSnOPT2 registers are 16-bit registers that control A/D conversion trigger output (TSnADTRG0 signal).

Access These registers can be read/written with a 16-bit, 8-bit, or 1-bit manipulation instruction.

TSnOPT2H can access the higher 8 bits of the TSnOPT2 register. TSnOPT2L can access the lower 8 bits of the TSnOPT2 register.

- $\begin{array}{c} \textbf{Address} \quad \text{TS0OPT2: FFFF5A0}_H \quad \text{TS0OPT2H: FFFF5A1}_H \quad \text{TS0OPT2L: FFFFF5A0}_H \\ \quad \text{TS1OPT2: FFFF5E0}_H \quad \text{TS1OPT2H: FFFFF5E1}_H \quad \text{TS1OPT2L: FFFFF5E0}_H \end{array}$
- Initial Value 0000<sub>H</sub>. These registers are cleared by any reset.

|          | 15     | 14     | 13     | 12     | 11     | 10     | 9      | 8      |
|----------|--------|--------|--------|--------|--------|--------|--------|--------|
| TSnOPT2  | 0      | 0      | 0      | 0      | 0      | 0      | TSnRTE | TSnRBE |
|          | R      | R      | R      | R      | R      | R      | R/W    | R/W    |
|          | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|          | TSnICE | TSnIOE | TSnRDE | TSnID4 | TSnID3 | TSnID2 | TSnID1 | TSnID0 |
|          | R/W    |
|          |        |        |        |        |        |        |        |        |
|          | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| TSnOPT2H | 0      | 0      | 0      | 0      | 0      | 0      | TSnRTE | TSnRBE |
|          | R      | R      | R      | R      | R      | R      | R/W    | R/W    |
|          |        |        |        |        |        |        |        |        |
|          | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| TSnOPT2L | TSnICE | TSnIOE | TSnRDE | TSnID4 | TSnID3 | TSnID2 | TSnID1 | TSnID0 |
|          | R/W    |
|          |        |        |        |        |        |        |        |        |

Caution

The write timing is delayed due to wait insertion during register access under the following conditions if serial write to the TSnOPT2 register is executed during the timer Sn operation (when TSnCTL0.TSnCE = 1)

| Write address | Next write address          | Write delay |
|---------------|-----------------------------|-------------|
| TSnOPT2L      | TSnOPT2, TSnOPT2L           | Delay       |
|               | TSnOPT2H                    | No delay    |
| TSnOPT2H      | TSnOPT2, TSnOPT2H           | Delay       |
|               | TSnOPT2L                    | No delay    |
| TSnOPT2       | TSnOPT2, TSnOPT2H, TSnOPT2L | Delay       |



| Bit<br>position | Bit name            |                                                     |                                         | Function                                                                                                                                                                                                              |
|-----------------|---------------------|-----------------------------------------------------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9,8             | TSnACC1,<br>TSnACC0 | Specifies the thin                                  | ning out ratio of t                     | he A/D conversion trigger (TSnADTRG0 signal).                                                                                                                                                                         |
|                 |                     | TSnACC1                                             | TSnACC0                                 | Thinning out Ratio                                                                                                                                                                                                    |
|                 |                     | 0                                                   | 0                                       | No thinning out                                                                                                                                                                                                       |
|                 |                     | 0                                                   | 1                                       | 1/2                                                                                                                                                                                                                   |
|                 |                     | 1                                                   | 0                                       | 1/3                                                                                                                                                                                                                   |
|                 |                     | 1                                                   | 1                                       | 1/4                                                                                                                                                                                                                   |
|                 |                     | TSnADTF                                             |                                         | tion (when TSnCTL0.TSnCE $=$ 1), the ng out counter is not cleared by write access to the                                                                                                                             |
|                 |                     | TSnA<br>TSnO                                        | DTRG0 signal the PT2 and TSnOP          | eration (when TSnCTL0.TSnCE = 1), the<br>inning out counter is cleared if write access to the<br>T2H registers is executed (including when the<br>to the TSnACC1 and TSnACC0 bits).                                   |
| 7               | TSnAT07             | timing when the 1<br>operation.<br>0: Don't use 16- | l6-bit sub-counte<br>bit sub-counter p  | version trigger (TSnADTRG0 signal) at the (peak)<br>r switches from count-up operation to count-down<br>eak timing as A/D conversion trigger.<br>ming as A/D conversion trigger.                                      |
|                 |                     |                                                     |                                         | an be set to 1 only in the high-accuracy T-PWM<br>et the TSnAT07 bit to 0 in any other mode.                                                                                                                          |
|                 |                     | 00                                                  |                                         | AT07 bit to 1 when TSnDTC0 $\neq$ 0000H, TSnDTC1 = nversion trigger is not generated at the peak timing unter.                                                                                                        |
| 6               | TSnAT06             | timing when the 1<br>operation.<br>0: Don't use 16- | l6-bit sub-counte<br>bit sub-counter ti | version trigger (TSnADTRG0 signal) at the (trough)<br>r switches from count-down operation to count-up<br>rough timing as A/D conversion trigger.<br>timing as A/D conversion trigger.                                |
|                 |                     | m<br>2. Do<br>00                                    | ode. Be sure to s                       | an be set to 1 only in the high-accuracy T-PWM<br>et the TSnAT06 bit to 0 in any other mode.<br>AT06 bit to 1 when TSnDTC0 = 0000H, TSnDTC1 $\neq$<br>nversion trigger is not generated at the trough<br>sub-counter. |

# Table 17-11 TSnOPT2 register contents (1/3)



| 21              |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 5               | TSnAT05  | <ul> <li>Enables generation of the A/D conversion trigger (TSnADTRG0 signal) when the INTTSnCC5 interrupt occurs during count-down operation of the 16-bit counter.</li> <li>0: Don't use occurrence of the INTTSnCC5 interrupt during the 16-bit counter count-down operation as A/D conversion trigger.</li> <li>1: Use occurrence of the INTTSnCC5 interrupt during the 16-bit counter count-down operation as A/D conversion trigger.</li> </ul> |
|                 |          | Caution: The TSnAT05 bit can be set to 1 only in the triangular-wave PWM mode<br>and high-accuracy T-PWM mode. Be sure to set TSnAT05 to 0 in any<br>other mode.                                                                                                                                                                                                                                                                                     |
| 4               | TSnAT04  | <ul> <li>Enables generation of the A/D conversion trigger (TSnADTRG0 signal) when the INTTSnCC5 interrupt occurs during count-up operation of the 16-bit counter.</li> <li>0: Don't use occurrence of the INTTSnCC5 interrupt during the 16-bit counter count-up operation as A/D conversion trigger.</li> <li>1: Use occurrence of the INTTSnCC5 interrupt during the 16-bit counter count-up operation as A/D conversion trigger.</li> </ul>       |
|                 |          | Caution: The TSnAT04 bit can be set to 1 only in the PWM mode, triangular-wave PWM mode, high-accuracy T-PWM mode, PWM mode with dead time, 120° excitation mode, special 120° excitation mode, and special pattern output mode. Be sure to set TSnAT04 to 0 in any other mode.                                                                                                                                                                      |
| 3               | TSnAT03  | <ul> <li>Enables generation of the A/D conversion trigger (TSnADTRG0 signal) when the INTTSnCC4 interrupt occurs during count-down operation of the 16-bit counter.</li> <li>0: Don't use occurrence of the INTTSnCC4 interrupt during the 16-bit counter count-down operation as A/D conversion trigger.</li> <li>1: Use occurrence of the INTTSnCC4 interrupt during the 16-bit counter count-down operation as A/D conversion trigger.</li> </ul> |
|                 |          | Caution: The TSnAT03 bit can be set to 1 only in the triangular-wave PWM mode<br>and high-accuracy T-PWM mode. Be sure to set TSnAT03 to 0 in any<br>other mode.                                                                                                                                                                                                                                                                                     |
| 2               | TSnAT02  | <ul> <li>Enables generation of the A/D conversion trigger (TSnADTRG0 signal) when the INTTSnCC4 interrupt occurs during count-up operation of the 16-bit counter.</li> <li>0: Don't use occurrence of the INTTSnCC4 interrupt during the 16-bit counter count-up operation as A/D conversion trigger.</li> <li>1: Use occurrence of the INTTSnCC4 interrupt during the 16-bit counter count-up operation as A/D conversion trigger.</li> </ul>       |
|                 |          | Caution: The TSnAT02 bit can be set to 1 only in the PWM mode, high-accuracy T-<br>PWM mode, triangular-wave PWM mode, PWM mode with dead-time,<br>120° excitation mode, special 120° excitation mode, and special pattern<br>output mode. Be sure to set TSnAT02 to 0 in any other mode.                                                                                                                                                            |

# Table 17-11 TSnOPT2 register contents (2/3)



| Bit<br>position    | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|--------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 1                  | TSnAT01  | <ul> <li>Enables the A/D conversion trigger (TSnADTRG0 signal) generation at the switch timing from count-up operation to count-down operation of the 16-bit counter (peak interrupt).</li> <li>0: Don't use the peak interrupt (INTTSnCD0) after thinning out as the A/D conversion trigger.</li> <li>1: Use the peak interrupt (INTTSnCD0) after thinning out as the A/D conversion trigger.</li> </ul>     |  |  |
|                    |          | Caution: The TSnAT01 bit can be set to 1 only in the PWM mode, high-accuracy T-<br>PWM mode, PWM mode with dead time, 120° excitation mode, special<br>120° excitation mode, and special pattern output mode. Be sure to set<br>TSnAT01 to 0 in any other mode.                                                                                                                                               |  |  |
| timi<br>inte<br>0: |          | <ul> <li>Enables the A/D conversion trigger (TSnADTRG0 signal) generation at the switch timing from count-up operation to count-down operation of the 16-bit counter (trough interrupt).</li> <li>0: Don't use the trough interrupt (INTTSnOD) after thinning out as the A/D conversion trigger.</li> <li>1: Use the trough interrupt (INTTSnOD) after thinning out as the A/D conversion trigger.</li> </ul> |  |  |
|                    |          | Caution: The TSnAT00 bit can be set to 1 only in the triangular-wave PWM mode<br>and high-accuracy T-PWM mode. Be sure to set TSnAT00 to 0 in any<br>other mode.                                                                                                                                                                                                                                              |  |  |

# Table 17-11 TSnOPT2 register contents (3/3)



Timer Sn option registers 3, 3H, 3L (TSnOPT3, TSnOPT3H, TSnOPT3L) (9)

The TSnOPT3 registers are 16-bit registers that control A/D conversion trigger output (TSnADTRG1 signal).

Access These registers can be read or written with a 16-bit, 8-bit, or 1-bit manipulation instruction.

TSnOPT3H enables access to the higher 8 bits of the TSnOPT3 register and TSnOPT3L enables access to the lower 8 bits of the TSnOPT3 register.

- **Address** TS0OPT3: FFFF5A2<sub>H</sub> TS0OPT3H: FFFFF5A3<sub>H</sub> TS0OPT3L: FFFFF5A2<sub>H</sub> TS10PT3: FFFF5E2<sub>H</sub> TS10PT3H: FFFF5E3<sub>H</sub> TS10PT3L: FFFFF5E2<sub>H</sub>
- **Initial Value** 0000<sub>H</sub>. These registers are cleared by any reset.

|          | 15      | 14      | 13      | 12      | 11      | 10      | 9       | 8       |
|----------|---------|---------|---------|---------|---------|---------|---------|---------|
| TSnOPT3  | 0       | 0       | 0       | 0       | 0       | 0       | TSnACC3 | TSnACC2 |
|          | R       | R       | R       | R       | R       | R       | R/W     | R/W     |
|          | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|          | TSnAT17 | TSnAT16 | TSnAT15 | TSnAT14 | TSnAT13 | TSnAT12 | TSnAT11 | TSnAT10 |
|          | R/W     |
|          |         |         |         |         |         |         |         |         |
|          | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
| TSnOPT3H | 0       | 0       | 0       | 0       | 0       | 0       | TSnACC3 | TSnACC2 |
|          | R       | R       | R       | R       | R       | R       | R/W     | R/W     |
|          |         |         |         |         |         |         |         |         |
|          | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
| TSnOPT3L | TSnAT17 | TSnAT16 | TSnAT15 | TSnAT14 | TSnAT13 | TSnAT12 | TSnAT11 | TSnAT10 |
|          | R/W     |
|          |         |         |         |         |         |         |         |         |

Caution

The write timing is delayed due to wait insertion during register access under the following conditions if serial write to the TSnOPT3 register is executed during the timer Sn operation (when the value of TSnCE of the TSnCTL0 register is 1).

| Write address | Next write address          | Write delay |  |
|---------------|-----------------------------|-------------|--|
| TSnOPT3L      | TSnOPT3, TSnOPT3L           | Delay       |  |
|               | TSnOPT3H                    | No delay    |  |
| TSnOPT3H      | TSnOPT3, TSnOPT3H           | Delay       |  |
|               | TSnOPT3L                    | No delay    |  |
| TSnOPT3       | TSnOPT3, TSnOPT3H, TSnOPT3L | Delay       |  |



| Bit<br>position | Bit name            | Function                                                                                                                                                                                                                                                                                                                                                           |                                         |                                                                                                                                                                                                                       |  |  |  |
|-----------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 9,8             | TSnACC3,<br>TSnACC2 | Specifies the thinning out ratio of the A/D conversion trigger (TSnADTRG1 signal).                                                                                                                                                                                                                                                                                 |                                         |                                                                                                                                                                                                                       |  |  |  |
|                 |                     | TSnACC3                                                                                                                                                                                                                                                                                                                                                            | TSnACC2                                 | Thinning out Ratio                                                                                                                                                                                                    |  |  |  |
|                 |                     | 0                                                                                                                                                                                                                                                                                                                                                                  | 0                                       | No thinning out                                                                                                                                                                                                       |  |  |  |
|                 |                     | 0                                                                                                                                                                                                                                                                                                                                                                  | 1                                       | 1/2                                                                                                                                                                                                                   |  |  |  |
|                 |                     | 1                                                                                                                                                                                                                                                                                                                                                                  | 0                                       | 1/3                                                                                                                                                                                                                   |  |  |  |
|                 |                     | 1                                                                                                                                                                                                                                                                                                                                                                  | 1                                       | 1/4                                                                                                                                                                                                                   |  |  |  |
|                 |                     | <b>Note:</b> During the timer Sn operation (when TSnCTL0.TSnCE = 1), the TSnADTRG1 signal thinning out counter is not cleared by write access to the TSnOPT3L register.                                                                                                                                                                                            |                                         |                                                                                                                                                                                                                       |  |  |  |
|                 |                     | Caution: During the timer Sn operation (when TSnCTL0.TSnCE = 1), the TSnADTRG1 signal thinning out counter is cleared if write access to the TSnOPT3 and TSnOPT3H registers is executed (including when the same value is written to the TSnACC3 and TSnACC2 bits).                                                                                                |                                         |                                                                                                                                                                                                                       |  |  |  |
| 7               | TSnAT17             | <ul> <li>Enables generation of the A/D conversion trigger (TSnADTRG1 signal) at the (peak) timing when the 16-bit sub-counter switches from count-up operation to count-down operation.</li> <li>0: Don't use 16-bit sub-counter peak timing as A/D conversion trigger.</li> <li>1: Use 16-bit sub-counter peak timing as A/D conversion trigger.</li> </ul>       |                                         |                                                                                                                                                                                                                       |  |  |  |
|                 |                     | Caution: 1. The TSnAT17 bit can be set to 1 only in the high-accuracy T-PWM mode. Be sure to set the TSnAT17 bit to 0 in any other mode.                                                                                                                                                                                                                           |                                         |                                                                                                                                                                                                                       |  |  |  |
|                 |                     | <ol> <li>Do not set the TSnAT17 bit to 1 when TSnDTC0 ≠ 0000H, TSnDTC1 =<br/>0000H. The A/D conversion trigger is not generated at the peak timing<br/>of the 16-bit sub-counter.</li> </ol>                                                                                                                                                                       |                                         |                                                                                                                                                                                                                       |  |  |  |
| 6               | TSnAT16             | <ul> <li>Enables generation of the A/D conversion trigger (TSnADTRG1 signal) at the (trough) timing when the 16-bit sub-counter switches from count-down operation to count-up operation.</li> <li>0: Don't use 16-bit sub-counter trough timing as A/D conversion trigger.</li> <li>1: Use 16-bit sub-counter trough timing as A/D conversion trigger.</li> </ul> |                                         |                                                                                                                                                                                                                       |  |  |  |
|                 |                     | 2. Do                                                                                                                                                                                                                                                                                                                                                              | ode. Be sure to s<br>o not set the TSn/ | an be set to 1 only in the high-accuracy T-PWM<br>et the TSnAT16 bit to 0 in any other mode.<br>AT16 bit to 1 when TSnDTC0 = 0000H, TSnDTC1 $\neq$<br>nversion trigger is not generated at the trough<br>sub-counter. |  |  |  |

# Table 17-12 TSnOPT3 register contents (1/3)



| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5               | TSnAT15  | <ul> <li>Enables generation of the A/D conversion trigger (TSnADTRG1 signal) when the INTTSnCC5 interrupt occurs during count-down operation of the 16-bit counter.</li> <li>0: Don't use occurrence of the INTTSnCC5 interrupt during the 16-bit counter count-down operation as A/D conversion trigger.</li> <li>1: Use occurrence of the INTTSnCC5 interrupt during the 16-bit counter count-down operation as A/D conversion trigger.</li> </ul> |
|                 |          | Caution: The TSnAT15 bit can be set to 1 only in the triangular-wave PWM mode<br>and high-accuracy T-PWM mode. Be sure to set TSnAT15 to 0 in any<br>other mode.                                                                                                                                                                                                                                                                                     |
| 4               | TSnAT14  | <ul> <li>Enables generation of the A/D conversion trigger (TSnADTRG1 signal) when the INTTSnCC5 interrupt occurred during count-up operation of the 16-bit counter.</li> <li>0: Don't use occurrence of the INTTSnCC5 interrupt during the 16-bit counter count-up operation as A/D conversion trigger.</li> <li>1: Use occurrence of the INTTSnCC5 interrupt during the 16-bit counter count-up operation as A/D conversion trigger.</li> </ul>     |
|                 |          | Caution: The TSnAT14 bit can be set to 1 only in the PWM mode, triangular-wave<br>PWM mode, high-accuracy T-PWM mode, PWM mode with dead time,<br>120° excitation mode, special 120° excitation mode, and special pattern<br>output mode. Be sure to set TSnAT14 to 0 in any other mode.                                                                                                                                                             |
| 3               | TSnAT13  | <ul> <li>Enables generation of the A/D conversion trigger (TSnADTRG1 signal) when the INTTSnCC4 interrupt occurs during count-down operation of the 16-bit counter.</li> <li>0: Don't use occurrence of the INTTSnCC4 interrupt during the 16-bit counter count-down operation as A/D conversion trigger.</li> <li>1: Use occurrence of the INTTSnCC4 interrupt during the 16-bit counter count-down operation as A/D conversion trigger.</li> </ul> |
|                 |          | Caution: The TSnAT13 bit can be set to 1 only in the triangular-wave PWM mode<br>and high-accuracy T-PWM mode. Be sure to set TSnAT13 to 0 in any<br>other mode.                                                                                                                                                                                                                                                                                     |
| 2               | TSnAT12  | <ul> <li>Enables generation of the A/D conversion trigger (TSnADTRG1 signal) when the INTTSnCC4 interrupt occurs during count-up operation of the 16-bit counter.</li> <li>0: Don't use occurrence of the INTTSnCC4 interrupt during the 16-bit counter count-up operation as A/D conversion trigger.</li> <li>1: Use occurrence of the INTTSnCC4 interrupt during the 16-bit counter count-up operation as A/D conversion trigger.</li> </ul>       |
|                 |          | Caution: The TSnAT12 bit can be set to 1 only in the PWM mode, high-accuracy T-<br>PWM mode, triangular-wave PWM mode, PWM mode with dead-time,<br>120° excitation mode, special 120° excitation mode, and special pattern<br>output mode. Be sure to set TSnAT12 to 0 in any other mode.                                                                                                                                                            |

## Table 17-12 TSnOPT3 register contents (2/3)



| Та              | able 17-12 | TSnOPT3 register contents (3/3)                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit<br>position | Bit name   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 1               | TSnAT11    | <ul> <li>Enables the A/D conversion trigger (TSnADTRG1 signal) generation at the switch timing from count-up operation to count-down operation of the 16-bit counter (peak interrupt).</li> <li>0: Don't use occurrence of the peak interrupt (INTTSnCD0) after thinning out as the A/D conversion trigger.</li> <li>1: Use occurrence of the peak interrupt (INTTSnCD0) after thinning out as the A/D conversion trigger.</li> </ul>     |
|                 |            | Caution: The TSnAT11 bit can be set to 1 only in the PWM mode, high-accuracy T-<br>PWM mode, PWM mode with dead time, 120° excitation mode, special<br>120° excitation mode, and special pattern output mode. Be sure to set<br>TSnAT11 to 0 in any other mode.                                                                                                                                                                           |
| 0               | TSnAT10    | <ul> <li>Enables the A/D conversion trigger (TSnADTRG1 signal) generation at the switch timing from count-up operation to count-down operation of the 16-bit counter (trough interrupt).</li> <li>0: Don't use occurrence of the trough interrupt (INTTSnOD) after thinning out as the A/D conversion trigger.</li> <li>1: Use occurrence of the trough interrupt (INTTSnOD) after thinning out as the A/D conversion trigger.</li> </ul> |
|                 |            | Caution: The TSnAT10 bit can be set to 1 only in the triangular-wave PWM mode<br>and high-accuracy T-PWM mode. Be sure to set TSnAT10 to 0 in any<br>other mode.                                                                                                                                                                                                                                                                          |

other mode.



| (10)          | Timer Sn option register 4 (TSnOPT4)                                                                                        |            |             |              |              |        |   |   |  |  |
|---------------|-----------------------------------------------------------------------------------------------------------------------------|------------|-------------|--------------|--------------|--------|---|---|--|--|
|               | The TSnOPT4 register is an 8-bit register that controls timer output (TOSn1 to TOSn6) by software and pattern output order. |            |             |              |              |        |   |   |  |  |
| Access        | This regist                                                                                                                 | er can be  | e read/writ | tten in 8-bi | t or 1-bit ι | units. |   |   |  |  |
| Address       | TS0OPT4:<br>TS1OPT4:                                                                                                        |            |             |              |              |        |   |   |  |  |
| Initial Value | 00 <sub>H</sub> . This r                                                                                                    | egister is | cleared b   | by any res   | et.          |        |   |   |  |  |
|               | 7                                                                                                                           | 6          | 5           | 4            | 3            | 2      | 1 | 0 |  |  |

|         | /      | 6 | 5 | 4 | 3      | 2       | 1       | 0       |
|---------|--------|---|---|---|--------|---------|---------|---------|
| TSnOPT4 | TSnSOC | 0 | 0 | 0 | TSnPSC | TSnIPC2 | TSnIPC1 | TSnIPC0 |
|         | R/W    | R | R | R | R/W    | R/W     | R/W     | R/W     |

## Table 17-13 TSnOPT4 register contents (1/2)

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7               | TSnSOC   | <ul> <li>Selects the timer output (TOSn1 to TOSn6) control by software</li> <li>0: Software control is disabled.</li> <li>1: Software control is enabled.</li> <li>When the TSnSOC bit is set to 1, timer output is switched to the output pattern of the software control function set by the TSnIPC2 to TSnIPC0 bits. Dead time is ensured by using the dead time 16-bit counter.</li> <li>Refer to <i>"Timer output initial pattern setting in each mode and function" on page 663</i> for details.</li> <li>Note: The setting of the TSnSOC bit is valid in the high-accuracy T-PWM mode, PWM mode with dead time, 120° excitation mode, and special excitation mode.</li> </ul>                                                                                                                                  |
|                 |          | <b>Caution:</b> The setting of TSnSOC = 1 and TSnADC of the TSnOPT5 register = 1 is prohibited.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3               | TSnPSC   | <ul> <li>Selects the pattern output order during semi-automatic driving.</li> <li>0: Switch the timer output (TOSn1 to TOSn6) into the normal rotation order.</li> <li>1: Switch the timer output (TOSn1 to TOSn6) into the reverse rotation order.</li> <li>The TSnSPC bit specifies the timer output pattern order with output pattern set with the TSnIPC2 to TSnIPC0 bits as the initial pattern in the 120° excitation mode, special 120° excitation mode, and 180° excitation control function. The TSnSPC bit is valid when TSnSOC of the TSnOPT5 register is set to 1, or when TSnSOC is set to 0, TSnPOT of the TSnOPT5 register is set to 1, and TSnPSS is set to 1.</li> <li>Note: Refer to <i>"Overview of 120° excitation mode" on page 852</i> for the normal/reverse rotation output order.</li> </ul> |
|                 |          | <ol> <li>Caution: 1. The TSnPSC bit must be changed when TSnCE is set to 0 or TSnPOT is set to 0. The timer output pattern may differ from the expected one if rewritten when TSnPOT is set to 1.</li> <li>2. TSnCE = 1 setting must be executed after matching the PSC bit order with the input signal variation logic when the signal input to the TAPTSn0 to TAPTSn2 pins varies while the timer Sn operation is stopped (when the TSnCE of the TSnCTL0 register is set to 0).</li> </ol>                                                                                                                                                                                                                                                                                                                          |



| Table 17-13 | TSnOPT4 register contents (2 | /2) |
|-------------|------------------------------|-----|
|             |                              | ~,  |

| Bit<br>position | Bit name        |              | Function                                                                                                                                                                                                                                                   |         |                                                                                                                                                                                                    |  |  |  |  |  |
|-----------------|-----------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 2 to 0          | TSnIPC<br>[2:0] | excitation m | et the initial pattern of the timer output in the 120° excitation mode, special 120°<br>xcitation mode and 180° excitation control function.<br>efer to <i>"Timer output initial pattern setting in each mode and function" on page 663</i><br>or details. |         |                                                                                                                                                                                                    |  |  |  |  |  |
|                 |                 | TSnIPC2      | TSnIPC1                                                                                                                                                                                                                                                    | TSnIPC0 | Operation                                                                                                                                                                                          |  |  |  |  |  |
|                 |                 | 0            | 0                                                                                                                                                                                                                                                          | 0       | Inactive output if there is no change from the<br>initial value (000B).<br>Output level remains the level before the change if<br>there is a change from any value to the initial<br>value (000B). |  |  |  |  |  |
|                 |                 | 1            | 1 1 1 The output level remains the level before the change.                                                                                                                                                                                                |         |                                                                                                                                                                                                    |  |  |  |  |  |
|                 |                 | Oth          | her than ab                                                                                                                                                                                                                                                | ove     | Timer output based on the pattern.                                                                                                                                                                 |  |  |  |  |  |



| Operation<br>mode               | TSnOPT4 .<br>TSnSOC | TSnOPT5.<br>TSnADC <sup>Note</sup> | Function of<br>TSnOPT4.TSnIPC[2:0]              | Output of TOSn1 to TOSn6 pins          |  |
|---------------------------------|---------------------|------------------------------------|-------------------------------------------------|----------------------------------------|--|
| High-accuracy                   | 1                   | 0                                  | Pattern setting                                 | Software 180° excitation               |  |
| T-PWM mode                      | 0                   | 1                                  | Initial pattern setting                         | Semi-automatic driving 180° excitation |  |
|                                 | 0                   | 0                                  | Not used                                        | High-accuracy T-PWM                    |  |
|                                 | 1                   | 1                                  | Setting prohibited                              |                                        |  |
| PWM mode                        | 1                   | 0                                  | Pattern setting                                 | Software 180° excitation               |  |
| with dead time                  | 0                   | 1                                  | Setting prohibited                              |                                        |  |
|                                 | 0                   | 0                                  | Not used                                        | PWM with dead time                     |  |
|                                 | 1                   | 1                                  | Setting prohibited                              |                                        |  |
| 120° excitation                 | 1                   | 0                                  | Pattern setting                                 | Software 180° excitation               |  |
| mode                            | 0                   | 1                                  | Initial pattern setting                         | Semi-automatic driving 180° excitation |  |
|                                 | 0                   | 0                                  | Pattern setting                                 | 120° excitation                        |  |
|                                 | 1                   | 1                                  | Setting prohibited                              |                                        |  |
| Special 120°<br>excitation mode | 1                   | 0                                  | Pattern setting for software output controlling | Software 180° excitation               |  |
|                                 | 0                   | 1                                  | Initial pattern setting                         | Semi-automatic driving 180° excitation |  |
|                                 | 0                   | 0                                  | Initial pattern setting                         | Special 120° excitation mode           |  |
|                                 | 1                   | 1                                  | Setting prohibited                              |                                        |  |

# (a) Function of the TSnIPC2 to TSnIPC0 bits and output of TOSn1 to TOSn6 pins by setting the TSnSOC and TSnADC bits

Caution

on The TSnOPT5.TSnPOT bit must be set to 1 if setting the TSnIPC[2:0] bits while using the 180° excitation control function.



#### (b) Timer output order in each mode and function

 In 120° excitation mode The TSnOPT4.TSnIPC[2:0] bits are set when TSnOPT5.TSnPOT bit is set to 1 while the timer Sn operation is stopped (when TSnCTL0.TSnCE is set to 0), and then timer output starts with the set pattern when the TSnCTL0.TSnCE bit is set to 1.

### Normal rotation:TSnOPT4 register: TSnSOC = 0, TSnPSC = 0, TSnOPT5 register: TSnPOT = 0, TSnPSS = 1, TSnOPT7 register: TSnIDC = 0





## Normal rotation:TSnOPT4 register: TSnSOC = 0, TSnPSC = 0, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 0



**Note** PWM1 to PWM4 indicate PWM output using the 16-bit counter and the TSnCCR1 to TSnCCR4 registers.

Reverse rotation: TSnOPT4 register: TSnSOC = 0, TSnPSC = 1, TSnOPT5 register: TSnPOT = 0, TSnPSS = 1, TSnOPT7 register: TSnIDC = 1





## Chapter 17

## Reverse rotation: TSnOPT4 register: TSnSOC = 0, TSnPSC = 1, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 1



**Note** PWM1 to PWM4 indicate PWM output using the 16-bit counter and the TSnCCR1 to TSnCCR4 registers.



• In special 120° excitation mode





Normal rotation:TSnOPT4 register: TSnSOC = 0, TSnPSC = 0, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 0





## 16-Bit Timer/Event Counter S (TMS)

## Chapter 17

## Reverse rotation: TSnOPT4 register: TSnSOC = 0, TSnPSC = 1, TSnOPT5 register: TSnPOT = 0, TSnPSS = 1, TSnOPT7 register: TSnIDC = 1





## Chapter 17

## Reverse rotation: TSnOPT4 register: TSnSOC = 0, TSnPSC = 1, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 1



**Caution** Special pattern 3 and special pattern 4 cannot be active simultaneously. Special pattern 0 and special pattern 7 cannot be active simultaneously either. The simultaneous active setting results in the following operations.

- 1. Only TOSn1, TOSn3, and TOSn5 are active during the simultaneous active period if TOSn1, TOSn3, and TOSn5 become active prior to TOSn2, TOSn4, and TOSn6.
- 2. Only TOSn2, TOSn4, and TOSn6 are active during the simultaneous active period if TOSn2, TOSn4, and TOSn6 become active prior to TOSn1, TOSn3, and TOSn5.
- **3.** Only TOSn1, TOSn3, and TOSn5 are active during the simultaneous active period if TOSn1, TOSn3, TOSn5, and TOSn2, TOSn4, TOSn6 become active simultaneously.
- Note Special patterns 0 to 3 are output using the TSnPAT0 register. Special pattern 0: Bits 3 to 0 Special pattern 1: Bits 7 to 4 Special pattern 2: Bits 11 to 8 Special pattern 3: Bits 15 to 12 Special patterns 4 to 7 are output using the TSnPAT1 register. Special pattern 4: Bits 3 to 0 Special pattern 5: Bits 7 to 4 Special pattern 6: Bits 11 to 8 Special pattern 7: Bits 15 to 12



• When using 180° excitation control function The TSnIPC[2:0] bits start timer output with the setting pattern when TSnADC is set to 1.

Normal rotation:TSnOPT4 register: TSnSOC = 0, TSnOPT5 register: TSnADC = 1, TSnPOT = 0, TSnOPT7 register: TSnIDC = 0









Reverse rotation: TSnOPT4 register: TSnSOC = 0, TSnOPT5 register: TSnADC = 1, TSnPOT = 0, TSnOPT7 register: TSnIDC = 1





## Reverse rotation: TSnOPT4 register: TSnSOC = 0, TSnOPT5 register: TSnADC = 1, TSnPOT = 1, TSnOPT7 register: TSnIDC = 1



Each phase (TOSn1 to TOSn6) outputs the active level for the period of electric angle  $180^{\circ}$  and then outputs the inactive level for the period of electric angle  $180^{\circ}$ .



## (c) Timer output initial pattern setting in each mode and function

• In 120° excitation mode

Normal rotation:TSnOPT4 register: TSnSOC = 0, TSnPSC = 0, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 0

|             |           |           |           | $\longrightarrow$ |           | Patt      | ern switch o | rder      |
|-------------|-----------|-----------|-----------|-------------------|-----------|-----------|--------------|-----------|
| Output pin  |           |           |           | TSnIPC2 t         | o TSnIPC0 |           |              |           |
| Output pill | [1, 0, 1] | [1, 0, 0] | [1, 1, 0] | [0, 1, 0]         | [0, 1, 1] | [0, 0, 1] | [0, 0, 0]    | [1, 1, 1] |
| TOSn1       | PWM1      | PWM2      | INACT     | INACT             | INACT     | INACT     | Note 1       | Note 2    |
| TOSn2       | INACT     | INACT     | INACT     | PWM3              | PWM4      | INACT     | Note 1       | Note 2    |
| TOSn3       | INACT     | INACT     | PWM1      | PWM2              | INACT     | INACT     | Note 1       | Note 2    |
| TOSn4       | PWM4      | INACT     | INACT     | INACT             | INACT     | PWM3      | Note 1       | Note 2    |
| TOSn5       | INACT     | INACT     | INACT     | INACT             | PWM1      | PWM2      | Note 1       | Note 2    |
| TOSn6       | INACT     | PWM3      | PWM4      | INACT             | INACT     | INACT     | Note 1       | Note 2    |

Normal rotation:TSnOPT4 register: TSnSOC = 0, TSnPSC = 0, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 1

|            |           |           |           | $\longrightarrow$ |           | Patt      | ern switch o | rder      |
|------------|-----------|-----------|-----------|-------------------|-----------|-----------|--------------|-----------|
| Output pin |           |           |           | TSnIPC2 t         | o TSnIPC0 |           |              |           |
| Output pin | [1, 0, 1] | [1, 0, 0] | [1, 1, 0] | [0, 1, 0]         | [0, 1, 1] | [0, 0, 1] | [0, 0, 0]    | [1, 1, 1] |
| TOSn1      | INACT     | INACT     | INACT     | PWM1              | PWM2      | INACT     | Note 1       | Note 2    |
| TOSn2      | PWM3      | PWM4      | INACT     | INACT             | INACT     | INACT     | Note 1       | Note 2    |
| TOSn3      | PWM2      | INACT     | INACT     | INACT             | INACT     | PWM1      | Note 1       | Note 2    |
| TOSn4      | INACT     | INACT     | PWM3      | PWM4              | INACT     | INACT     | Note 1       | Note 2    |
| TOSn5      | INACT     | PWM1      | PWM2      | INACT             | INACT     | INACT     | Note 1       | Note 2    |
| TOSn6      | INACT     | INACT     | INACT     | INACT             | PWM3      | PWM4      | Note 1       | Note 2    |

**Note 1.** INACT if no change from the initial value. If the value is changed from any value to [0, 0, 0], the output remains the level before the change.

- 2. Output remains the level before the change.
- 3. PWM1 to PWM4: PWM output from TSnCCR1 to TSnCCR4 registers
- 4. INACT: Inactive level output



Reverse rotation: TSnOPT4 register: TSnSOC = 0, TSnPSC = 1, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 0

|            | ←         |                    |           |           |           | Patt      | ern switch o | rder      |  |  |  |
|------------|-----------|--------------------|-----------|-----------|-----------|-----------|--------------|-----------|--|--|--|
| Output pin |           | TSnIPC2 to TSnIPC0 |           |           |           |           |              |           |  |  |  |
| Output pin | [1, 0, 1] | [1, 0, 0]          | [1, 1, 0] | [0, 1, 0] | [0, 1, 1] | [0, 0, 1] | [0, 0, 0]    | [1, 1, 1] |  |  |  |
| TOSn1      | PWM2      | PWM1               | INACT     | INACT     | INACT     | INACT     | Note 1       | Note 2    |  |  |  |
| TOSn2      | INACT     | INACT              | INACT     | PWM4      | PWM3      | INACT     | Note 1       | Note 2    |  |  |  |
| TOSn3      | INACT     | INACT              | PWM2      | PWM1      | INACT     | INACT     | Note 1       | Note 2    |  |  |  |
| TOSn4      | PWM3      | INACT              | INACT     | INACT     | INACT     | PWM4      | Note 1       | Note 2    |  |  |  |
| TOSn5      | INACT     | INACT              | INACT     | INACT     | PWM2      | PWM1      | Note 1       | Note 2    |  |  |  |
| TOSn6      | INACT     | PWM4               | PWM3      | INACT     | INACT     | INACT     | Note 1       | Note 2    |  |  |  |

Reverse rotation: TSnOPT4 register: TSnSOC = 0, TSnPSC = 1, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1,

TSnOPT7 register: TSnIDC = 1

|            | ←         |                    | · · · · · · · · |           |           | Patt      | ern switch o | rder      |  |  |  |
|------------|-----------|--------------------|-----------------|-----------|-----------|-----------|--------------|-----------|--|--|--|
| Output pin |           | TSnIPC2 to TSnIPC0 |                 |           |           |           |              |           |  |  |  |
| Output pin | [1, 0, 1] | [1, 0, 0]          | [1, 1, 0]       | [0, 1, 0] | [0, 1, 1] | [0, 0, 1] | [0, 0, 0]    | [1, 1, 1] |  |  |  |
| TOSn1      | INACT     | INACT              | INACT           | PWM2      | PWM1      | INACT     | Note 1       | Note 2    |  |  |  |
| TOSn2      | PWM4      | PWM3               | INACT           | INACT     | INACT     | INACT     | Note 1       | Note 2    |  |  |  |
| TOSn3      | PWM1      | INACT              | INACT           | INACT     | INACT     | PWM2      | Note 1       | Note 2    |  |  |  |
| TOSn4      | INACT     | INACT              | PWM4            | PWM3      | INACT     | PWM3      | Note 1       | Note 2    |  |  |  |
| TOSn5      | INACT     | PWM2               | PWM1            | INACT     | INACT     | INACT     | Note 1       | Note 2    |  |  |  |
| TOSn6      | INACT     | INACT              | INACT           | INACT     | PWM4      | PWM3      | Note 1       | Note 2    |  |  |  |

Note 1. INACT if no change from the initial value. If the value is changed from any value to [0, 0, 0], the output remains the level before the change.

- 2. Output remains the level before the change.
- 3. PWM1 to PWM4: PWM output from TSnCCR1 to TSnCCR4 registers
- 4. INACT: Inactive level output



## • In special 120° excitation mode

## Normal rotation:TSnOPT4 register: TSnSOC = 0, TSnPSC = 0, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 0

|        |                   |                   |                   |                   | Patterr           | n switch or       | der       |           |
|--------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-----------|-----------|
| Output |                   |                   | SnIPC0            |                   |                   |                   |           |           |
| pin    | [1, 0, 1]         | [1, 0, 0]         | [1, 1, 0]         | [0, 1, 0]         | [0, 1, 1]         | [0, 0, 1]         | [0, 0, 0] | [1, 1, 1] |
| TOSn1  | Special pattern 1 | Special pattern 2 | Special pattern 3 | INACT             | INACT             | Special pattern 0 | Note 1    | Note 2    |
| TOSn2  | INACT             | INACT             | Special pattern 4 | Special pattern 5 | Special pattern 6 | Special pattern 7 | Note 1    | Note 2    |
| TOSn3  | INACT             | Special pattern 0 | Special pattern 1 | Special pattern 2 | Special pattern 3 | INACT             | Note 1    | Note 2    |
| TOSn4  | Special pattern 6 | Special pattern 7 | INACT             | INACT             | Special pattern 4 | Special pattern 5 | Note 1    | Note 2    |
| TOSn5  | Special pattern 3 | INACT             | INACT             | Special pattern 0 | Special pattern 1 | Special pattern 2 | Note 1    | Note 2    |
| TOSn6  | Special pattern 4 | Special pattern 5 | Special pattern 6 | Special pattern 7 | INACT             | INACT             | Note 1    | Note 2    |

Normal rotation:TSnOPT4 register: TSnSOC = 0, TSnPSC = 0, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 1

| Output |                      |                      | 1                 | SnIPC2 to T          | SnIPC0            |                   |           |           |  |  |
|--------|----------------------|----------------------|-------------------|----------------------|-------------------|-------------------|-----------|-----------|--|--|
| pin    | [1, 0, 1]            | [1, 0, 0]            | [1, 1, 0]         | [0, 1, 0]            | [0, 1, 1]         | [0, 0, 1]         | [0, 0, 0] | [1, 1, 1] |  |  |
| TOSn1  | INACT                | INACT                | Special pattern 0 | Special<br>pattern 1 | Special pattern 2 | Special pattern 3 | Note 1    | Note 2    |  |  |
| TOSn2  | Special pattern 5    | Special pattern 6    | Special pattern 7 | INACT                | INACT             | Special pattern 4 | Note 1    | Note 2    |  |  |
| TOSn3  | Special pattern 2    | Special pattern 3    | INACT             | INACT                | Special pattern 0 | Special pattern 1 | Note 1    | Note 2    |  |  |
| TOSn4  | INACT                | Special pattern 4    | Special pattern 5 | Special pattern 6    | Special pattern 7 | INACT             | Note 1    | Note 2    |  |  |
| TOSn5  | Special<br>pattern 0 | Special<br>pattern 1 | Special pattern 2 | Special pattern 3    | INACT             | INACT             | Note 1    | Note 2    |  |  |
| TOSn6  | Special pattern 7    | INACT                | INACT             | Special pattern 4    | Special pattern 5 | Special pattern 6 | Note 1    | Note 2    |  |  |

**Note** 1. INACT if no change from the initial value. If changed from any value to [0, 0, 0], output remains the level before the change.

2. Output remains the level before the change.



**Caution** Special pattern 3 and special pattern 4 cannot be active simultaneously. Special pattern 0 and special pattern 7 cannot be active simultaneously either. The simultaneous active setting results in the following operations.

1. Only TOSn1, TOSn3, and TOSn5 are active during the simultaneous active period if

TOSn1, TOSn3, and TOSn5 become active prior to TOSn2, TOSn4, and TOSn6.

- 2. Only TOSn2, TOSn4, and TOSn6 are active during the simultaneous active period if TOSn2, TOSn4 and TOSn6 become active prior to TOSn1, TOSn3, and TOSn5.
- **3.** Only TOSn1, TOSn3, and TOSn5 are active during the simultaneous active period if TOSn1, TOSn3, TOSn5, and TOSn2, TOSn4, TOSn6 become active simultaneously.
- Note 1. Special patterns 0 to 7: Special pattern output by TSnCCR0 to TSnCCR3, TSnPAT0, and TSnPAT1 registers
  - 2. INACT: Inactive level output

Reverse rotation: TSnOPT4 register: TSnSOC = 0, TSnPSC = 1, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 0

|        | ← Pattern switch  |                    |                   |                   |                   |                   |           |           |  |  |  |  |  |
|--------|-------------------|--------------------|-------------------|-------------------|-------------------|-------------------|-----------|-----------|--|--|--|--|--|
| Output |                   | TSnIPC2 to TSnIPC0 |                   |                   |                   |                   |           |           |  |  |  |  |  |
| pin    | [1, 0, 1]         | [1, 0, 0]          | [1, 1, 0]         | [0, 1, 0]         | [0, 1, 1]         | [0, 0, 1]         | [0, 0, 0] | [1, 1, 1] |  |  |  |  |  |
| TOSn1  | Special pattern 2 | Special pattern 1  | Special pattern 0 | INACT             | INACT             | Special pattern 3 | Note 1    | Note 2    |  |  |  |  |  |
| TOSn2  | INACT             | INACT              | Special pattern 7 | Special pattern 6 | Special pattern 5 | Special pattern 4 | Note 1    | Note 2    |  |  |  |  |  |
| TOSn3  | INACT             | Special pattern 3  | Special pattern 2 | Special pattern 1 | Special pattern 0 | INACT             | Note 1    | Note 2    |  |  |  |  |  |
| TOSn4  | Special pattern 5 | Special pattern 4  | INACT             | INACT             | Special pattern 7 | Special pattern 6 | Note 1    | Note 2    |  |  |  |  |  |
| TOSn5  | Special pattern 0 | INACT              | INACT             | Special pattern 3 | Special pattern 2 | Special pattern 1 | Note 1    | Note 2    |  |  |  |  |  |
| TOSn6  | Special pattern 7 | Special pattern 6  | Special pattern 5 | Special pattern 4 | INACT             | INACT             | Note 1    | Note 2    |  |  |  |  |  |

Pattern switch order



## Reverse rotation: TSnOPT4 register: TSnSOC = 0, TSnPSC = 1, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 1

| Output | TSnIPC2 to TSnIPC0   |                   |                      |                   |                   |                   |           |           |  |  |  |  |
|--------|----------------------|-------------------|----------------------|-------------------|-------------------|-------------------|-----------|-----------|--|--|--|--|
| pin    | [1, 0, 1]            | [1, 0, 0]         | [1, 1, 0]            | [0, 1, 0]         | [0, 1, 1]         | [0, 0, 1]         | [0, 0, 0] | [1, 1, 1] |  |  |  |  |
| TOSn1  | INACT                | INACT             | Special pattern 3    | Special pattern 2 | Special pattern 1 | Special pattern 0 | Note 1    | Note 2    |  |  |  |  |
| TOSn2  | Special pattern 6    | Special pattern 5 | Special pattern 4    | INACT             | INACT             | Special pattern 7 | Note 1    | Note 2    |  |  |  |  |
| TOSn3  | Special<br>pattern 1 | Special pattern 0 | INACT                | INACT             | Special pattern 3 | Special pattern 2 | Note 1    | Note 2    |  |  |  |  |
| TOSn4  | INACT                | Special pattern 7 | Special pattern 6    | Special pattern 5 | Special pattern 4 | INACT             | Note 1    | Note 2    |  |  |  |  |
| TOSn5  | Special pattern 3    | Special pattern 2 | Special<br>pattern 1 | Special pattern 0 | INACT             | INACT             | Note 1    | Note 2    |  |  |  |  |
| TOSn6  | Special pattern 4    | INACT             | INACT                | Special pattern 7 | Special pattern 6 | Special pattern 5 | Note 1    | Note 2    |  |  |  |  |

Pattern switch order

- **Note** 1. INACT if no change from the initial value. If the value is changed from any value to [0, 0, 0], output remains the level before the change.
  - 2. Output remains the level before the change.

Caution Special pattern 3 and special pattern 4 cannot be active simultaneously. Special pattern 0 and special pattern 7 cannot be active simultaneously either. The simultaneous active setting leads the following operations.

- 1. Only TOSn1, TOSn3, and TOSn5 are active during the simultaneous active period if TOSn1, TOSn3, and TOSn5 become active prior to TOSn2, TOSn4, and TOSn6.
- 2. Only TOSn2, TOSn4, and TOSn6 are active during the simultaneous active period if TOSn2, TOSn4, and TOSn6 become active prior to TOSn1, TOSn3, and TOSn5.
- **3.** Only TOSn1, TOSn3, and TOSn5 are active during the simultaneous active period if TOSn1, TOSn3, TOSn5, and TOSn2, TOSn4, TOSn6 become active simultaneously.
- Note 1. Special patterns 0 to 7:Special pattern output by TSnCCR0 to TSnCCR3, TSnPAT0, and TSnPAT1 registers
  - 2. INACT: Inactive level output



## • When using 180° excitation function

TSnOPT4 register: TSnSOC = 0, TSnOPT5 register: TSnADC = 1, TSnPOT = 1, TSnOPT7 register: TSnIDC = 0

| Output pin |           | TSnIPC2 to TSnIPC0 |           |           |           |           |           |           |  |  |  |
|------------|-----------|--------------------|-----------|-----------|-----------|-----------|-----------|-----------|--|--|--|
| output pin | [1, 0, 1] | [1, 0, 0]          | [1, 1, 0] | [0, 1, 0] | [0, 1, 1] | [0, 0, 1] | [0, 0, 0] | [1, 1, 1] |  |  |  |
| TOSn1      | ACT       | ACT                | ACT       | INACT     | INACT     | INACT     | Note 1    | Note 2    |  |  |  |
| TOSn2      | INACT     | INACT              | INACT     | ACT       | ACT       | ACT       | Note 1    | Note 2    |  |  |  |
| TOSn3      | INACT     | INACT              | ACT       | ACT       | ACT       | INACT     | Note 1    | Note 2    |  |  |  |
| TOSn4      | ACT       | ACT                | INACT     | INACT     | INACT     | ACT       | Note 1    | Note 2    |  |  |  |
| TOSn5      | ACT       | INACT              | INACT     | INACT     | ACT       | ACT       | Note 1    | Note 2    |  |  |  |
| TOSn6      | INACT     | ACT                | ACT       | ACT       | INACT     | INACT     | Note 1    | Note 2    |  |  |  |

TSnOPT4 register: TSnSOC = 0, TSnOPT5 register: TSnADC = 1, TSnPOT = 1, TSnOPT7 register: TSnIDC = 1

| Output pin | TSnIPC2 to TSnIPC0 |           |           |           |           |           |           |           |  |  |
|------------|--------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|--|--|
| Output pin | [1, 0, 1]          | [1, 0, 0] | [1, 1, 0] | [0, 1, 0] | [0, 1, 1] | [0, 0, 1] | [0, 0, 0] | [1, 1, 1] |  |  |
| TOSn1      | INACT              | INACT     | INACT     | ACT       | ACT       | ACT       | Note 1    | Note 2    |  |  |
| TOSn2      | ACT                | ACT       | ACT       | INACT     | INACT     | INACT     | Note 1    | Note 2    |  |  |
| TOSn3      | ACT                | ACT       | INACT     | INACT     | INACT     | ACT       | Note 1    | Note 2    |  |  |
| TOSn4      | INACT              | INACT     | ACT       | ACT       | ACT       | INACT     | Note 1    | Note 2    |  |  |
| TOSn5      | INACT              | ACT       | ACT       | ACT       | INACT     | INACT     | Note 1    | Note 2    |  |  |
| TOSn6      | ACT                | INACT     | INACT     | INACT     | ACT       | ACT       | Note 1    | Note 2    |  |  |

**Note 1.** INACT if no change from the initial value. If the value is changed from any value to [0, 0, 0], output remains the level before the change.

- 2. Output remains the level before the change.
- 3. ACT: Active level output
- 4. INACT: Inactive level output



| (11)          | Timer Sn option register 5 (TSnOPT5)                                                                                                |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------|
|               | The TSnOPT5 register is an 8-bit register that controls 180° excitation control function and timer output (TOSn1 to TOSn6) pattern. |
| Access        | This register can be read/written in 8-bit or 1-bit units.                                                                          |
| Address       | TS0OPT5: FFFFF589 <sub>H</sub><br>TS1OPT5: FFFFF5C9 <sub>H</sub>                                                                    |
| Initial Value | 00 <sub>H</sub> . This register is cleared by any reset.                                                                            |

| 7      | 6      | 5      | 4      | 3      | 2       | 1       | 0       |
|--------|--------|--------|--------|--------|---------|---------|---------|
| TSnADC | TSnPOT | TSnPSS | TSnPTS | TSnTSF | TSnOPF2 | TSnOPF1 | TSnOPF0 |
| R/W    | R/W    | R/W    | R/W    | R/W    | R/W     | R/W     | R/W     |

## Table 17-14 TSnOPT5 register contents (1/2)

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7               | TSnADC   | <ul> <li>Selects the 180° excitation control function of semi-automatic driving.</li> <li>0: Semi-automatic driving 180° excitation control function disabled</li> <li>1: Semi-automatic driving 180° excitation control function enabled</li> <li>When the TSnADC bit is set to 1, the timer output pattern is switched to the pattern preset by the TSnOPT4.TSnIPC[2:0] bits. Upon input of the next pattern output trigger, the next pattern is output.</li> <li>Note: The TSnADC bit is valid in the high-accuracy T-PWM mode, 120° excitation mode, and special 120° excitation mode.</li> </ul> |
|                 |          | <ol> <li>Set the output pattern to TSnIPC[2:0] bits in advance before setting TSnADC to 1.</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 6               | TSnPOT   | <ul> <li>Selects the pattern output trigger.</li> <li>Output pattern switch by using external pattern input pins (TAPTSn0 to TAPTSn2 pins) (pattern switch method).</li> <li>1: Output pattern switch by rising edge of the TSnSTCI0 and TSnSTCI1signals (trigger switch method).</li> <li>Note: The TSnPOT bit setting is valid in the 120° excitation mode, special 120° excitation mode and during 180° excitation control in each mode.</li> </ul>                                                                                                                                                |
| 5               | TSnPSS   | Selects the pattern output switch factor.<br>0: Switch the pattern output order using input signal to the TSnARD signal.<br>1: Switch the pattern output order using the TSnOPT4.TSnPSC bit.<br>Caution: The TSnPSS bit is valid only when the TSnPOT bit is set to 1.                                                                                                                                                                                                                                                                                                                                |



| Bit<br>position | Bit name        |                                                                                                                                                                                                                  | Function                                                                                                                                                                                                                                               |  |  |  |  |  |  |
|-----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 4               | TSnPTS          | <ul> <li>0: Disable toggle output to<br/>detection timing of TAP</li> <li>1: Enable toggle output to<br/>detection timing of the T</li> <li>The level of the TSnAEDO a<br/>changed from 1 to 0 during</li> </ul> | the TSNAEDO and TSNESG <sup>Note</sup> signals at the edge<br>TAPTSn[2:0] pins.<br>and TSNESG signals is retained if the TSNPTS bit is<br>the timer Sn operation (when TSnCTL0.TSnCE = 1).<br>is provided only in the 120° excitation mode and special |  |  |  |  |  |  |
| 3               | TSnTSF          | pins.<br>0: TAPTSn[2:0] pins are in                                                                                                                                                                              | This is a flag that indicates the order of pattern change detected with the TAPTSn[2:0]<br>bins.<br>0: TAPTSn[2:0] pins are input in the normal rotation order.<br>1: TAPTSn[2:0] pins are input in the reverse rotation order.                        |  |  |  |  |  |  |
|                 |                 | Normal rotation                                                                                                                                                                                                  | <b></b>                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|                 |                 | Reverse rotation                                                                                                                                                                                                 | ·                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
|                 |                 | TAPTSn[2:0] pins                                                                                                                                                                                                 | [1, 0, 1] [1, 0, 0] [1, 1, 0] [0, 1, 0] [0, 1, 1] [0, 0, 1]                                                                                                                                                                                            |  |  |  |  |  |  |
|                 |                 | of the TAPTSn[2:0]                                                                                                                                                                                               | or reverse rotation can be detected after the first change<br>bins after TSnCTL0.TSnCE = 1 is set.<br><i>"Input pattern change order detection" on page 679</i> .                                                                                      |  |  |  |  |  |  |
| 2 to 0          | TSnOPF<br>[2:0] | Refer to <i>"Timer output patte</i><br>The TSnOPF[2:0] bits are d                                                                                                                                                | e the pattern output of the timer output (TOSn1 to TOSn6).<br><i>rn in each mode and function" on page 671</i> for details.<br>isplayed in the 120° excitation mode, special 120°<br>using 180° excitation control function.                           |  |  |  |  |  |  |

# Table 17-14 TSnOPT5 register contents (2/2)



## (a) Timer output pattern in each mode and function

Software control function

TSnOPT4 register: TSnSOC = 1, TSnOPT7 register: TSnIDC = 0

| Output pin  | TSnOPF2 to TSnOPF0 |           |           |           |           |           |           |           |  |  |
|-------------|--------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|--|--|
| Output pill | [1, 0, 1]          | [1, 0, 0] | [1, 1, 0] | [0, 1, 0] | [0, 1, 1] | [0, 0, 1] | [0, 0, 0] | [1, 1, 1] |  |  |
| TOSn1       | ACT                | ACT       | ACT       | INACT     | INACT     | INACT     | Note 1    | Note 2    |  |  |
| TOSn2       | INACT              | INACT     | INACT     | ACT       | ACT       | ACT       | Note 1    | Note 2    |  |  |
| TOSn3       | INACT              | INACT     | ACT       | ACT       | ACT       | INACT     | Note 1    | Note 2    |  |  |
| TOSn4       | ACT                | ACT       | INACT     | INACT     | INACT     | ACT       | Note 1    | Note 2    |  |  |
| TOSn5       | ACT                | INACT     | INACT     | INACT     | ACT       | ACT       | Note 1    | Note 2    |  |  |
| TOSn6       | INACT              | ACT       | ACT       | ACT       | INACT     | INACT     | Note 1    | Note 2    |  |  |

## TSnOPT4 register: TSnSOC = 1, TSnOPT7 register: TSnIDC = 1

| Output pin | TSnOPF2 to TSnOPF0 |           |           |           |           |           |           |           |  |  |
|------------|--------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|--|--|
| Output pin | [1, 0, 1]          | [1, 0, 0] | [1, 1, 0] | [0, 1, 0] | [0, 1, 1] | [0, 0, 1] | [0, 0, 0] | [1, 1, 1] |  |  |
| TOSn1      | INACT              | INACT     | INACT     | ACT       | ACT       | ACT       | Note 1    | Note 2    |  |  |
| TOSn2      | ACT                | ACT       | ACT       | INACT     | INACT     | INACT     | Note 1    | Note 2    |  |  |
| TOSn3      | ACT                | ACT       | INACT     | INACT     | INACT     | ACT       | Note 1    | Note 2    |  |  |
| TOSn4      | INACT              | INACT     | ACT       | ACT       | ACT       | INACT     | Note 1    | Note 2    |  |  |
| TOSn5      | INACT              | ACT       | ACT       | ACT       | INACT     | INACT     | Note 1    | Note 2    |  |  |
| TOSn6      | ACT                | INACT     | INACT     | INACT     | ACT       | ACT       | Note 1    | Note 2    |  |  |

**Note** 1. INACT if no change from the initial value. If the value is changed from any value to [0, 0, 0], output remains the output level before the change.

- 2. Output level remains the level before the change.
- 3. ACT: Active level output
- 4. INACT: Inactive level output



• In 120° excitation mode

Normal rotation:TSnOPT4 register: TSnSOC = 0, TSnARD signal or TSnPSC = 0, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 0

|             |                    |           |           |           |           | Patt      | ern switch o | rder      |  |
|-------------|--------------------|-----------|-----------|-----------|-----------|-----------|--------------|-----------|--|
| Output pin  | TSnOPF2 to TSnOPF0 |           |           |           |           |           |              |           |  |
| Output pill | [1, 0, 1]          | [1, 0, 0] | [1, 1, 0] | [0, 1, 0] | [0, 1, 1] | [0, 0, 1] | [0, 0, 0]    | [1, 1, 1] |  |
| TOSn1       | PWM1               | PWM2      | INACT     | INACT     | INACT     | INACT     | Note 1       | Note 2    |  |
| TOSn2       | INACT              | INACT     | INACT     | PWM3      | PWM4      | INACT     | Note 1       | Note 2    |  |
| TOSn3       | INACT              | INACT     | PWM1      | PWM2      | INACT     | INACT     | Note 1       | Note 2    |  |
| TOSn4       | PWM4               | INACT     | INACT     | INACT     | INACT     | PWM3      | Note 1       | Note 2    |  |
| TOSn5       | INACT              | INACT     | INACT     | INACT     | PWM1      | PWM2      | Note 1       | Note 2    |  |
| TOSn6       | INACT              | PWM3      | PWM4      | INACT     | INACT     | INACT     | Note 1       | Note 2    |  |

Normal rotation:TSnOPT4 register: TSnSOC = 0, TSnARD signal or TSnPSC= 0, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1

TSnOPT5 register: TSnPOT = 1, TSnPSS = 1,

TSnOPT7 register: TSnIDC = 1

Pattern switch order

| Output pin | TSnOPF2 to TSnOPF0 |           |           |           |           |           |           |           |  |  |
|------------|--------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|--|--|
| Output pin | [1, 0, 1]          | [1, 0, 0] | [1, 1, 0] | [0, 1, 0] | [0, 1, 1] | [0, 0, 1] | [0, 0, 0] | [1, 1, 1] |  |  |
| TOSn1      | INACT              | INACT     | INACT     | PWM1      | PWM2      | INACT     | Note 1    | Note 2    |  |  |
| TOSn2      | PWM3               | PWM4      | INACT     | INACT     | INACT     | INACT     | Note 1    | Note 2    |  |  |
| TOSn3      | PWM2               | INACT     | INACT     | INACT     | INACT     | PWM1      | Note 1    | Note 2    |  |  |
| TOSn4      | INACT              | INACT     | PWM3      | PWM4      | INACT     | INACT     | Note 1    | Note 2    |  |  |
| TOSn5      | INACT              | PWM1      | PWM2      | INACT     | INACT     | INACT     | Note 1    | Note 2    |  |  |
| TOSn6      | INACT              | INACT     | INACT     | INACT     | PWM3      | PWM4      | Note 1    | Note 2    |  |  |

**Note** 1. INACT if no change from the initial value. If the value is changed from any value to [0, 0, 0], output remains the output level before the change.

- 2. Output remains the level before the change.
- 3. PWM1 to PWM4: PWM output from TSnCCR1 to TSnCCR4 registers
- 4. INACT: Inactive level output

Reverse rotation: TSnOPT4 register: TSnSOC = 0, TSnARD signal or TSnPSC = 1, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 0

Reverse rotation: TSnOPT4 register: TSnSOC = 0, TSnARD signal or TSnPSC = 1, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 1

RENESAS

| Arrow Pattern switch or |                    |           |           |           |           |           |           | rder      |  |  |  |
|-------------------------|--------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|--|--|--|
| Output pin              | TSnOPF2 to TSnOPF0 |           |           |           |           |           |           |           |  |  |  |
| Output pin              | [1, 0, 1]          | [1, 0, 0] | [1, 1, 0] | [0, 1, 0] | [0, 1, 1] | [0, 0, 1] | [0, 0, 0] | [1, 1, 1] |  |  |  |
| TOSn1                   | PWM2               | PWM1      | INACT     | INACT     | INACT     | INACT     | Note 1    | Note 2    |  |  |  |
| TOSn2                   | INACT              | INACT     | INACT     | PWM4      | PWM3      | INACT     | Note 1    | Note 2    |  |  |  |
| TOSn3                   | INACT              | INACT     | PWM 2     | PWM 1     | INACT     | INACT     | Note 1    | Note 2    |  |  |  |
| TOSn4                   | PWM3               | INACT     | INACT     | INACT     | INACT     | PWM4      | Note 1    | Note 2    |  |  |  |
| TOSn5                   | INACT              | INACT     | INACT     | INACT     | PWM2      | PWM1      | Note 1    | Note 2    |  |  |  |
| TOSn6                   | INACT              | PWM4      | PWM3      | INACT     | INACT     | INACT     | Note 1    | Note 2    |  |  |  |

Pattern switch order

| Output pin | TSnOPF2 to TSnOPF0 |           |           |           |           |           |           |           |  |  |
|------------|--------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|--|--|
| Output pin | [1, 0, 1]          | [1, 0, 0] | [1, 1, 0] | [0, 1, 0] | [0, 1, 1] | [0, 0, 1] | [0, 0, 0] | [1, 1, 1] |  |  |
| TOSn1      | INACT              | INACT     | INACT     | PWM 2     | PWM 1     | INACT     | Note 1    | Note 2    |  |  |
| TOSn2      | PWM4               | PWM3      | INACT     | INACT     | INACT     | INACT     | Note 1    | Note 2    |  |  |
| TOSn3      | PWM1               | INACT     | INACT     | INACT     | INACT     | PWM2      | Note 1    | Note 2    |  |  |
| TOSn4      | INACT              | INACT     | PWM4      | PWM3      | INACT     | INACT     | Note 1    | Note 2    |  |  |
| TOSn5      | INACT              | PWM 2     | PWM1      | INACT     | INACT     | INACT     | Note 1    | Note 2    |  |  |
| TOSn6      | INACT              | INACT     | INACT     | INACT     | PWM4      | PWM3      | Note 1    | Note 2    |  |  |
|            |                    |           |           |           |           |           |           |           |  |  |

Note 1. INACT if no change from the initial value. If the value is changed from any value to [0, 0, 0], output remains the level before the change.

- 2. Output remains the level before the change.
- 3. PWM1 to PWM4: PWM output from TSnCCR1 to TSnCCR4 registers
- 4. INACT: Inactive level output



## • In special 120° excitation mode

Normal rotation:TSnOPT4 register: TSnSOC = 0, TSnARD signal or TSnPSC = 0, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 0

|        |                   | → Patte            |                   |                   |                   |                   |           |           |  |  |  |
|--------|-------------------|--------------------|-------------------|-------------------|-------------------|-------------------|-----------|-----------|--|--|--|
| Output |                   | TSnOPF2 to TSnOPF0 |                   |                   |                   |                   |           |           |  |  |  |
| pin    | [1, 0, 1]         | [1, 0, 0]          | [1, 1, 0]         | [0, 1, 0]         | [0, 1, 1]         | [0, 0, 1]         | [0, 0, 0] | [1, 1, 1] |  |  |  |
| TOSn1  | Special pattern 1 | Special pattern 2  | Special pattern 3 | INACT             | INACT             | Special pattern 0 | Note 1    | Note 2    |  |  |  |
| TOSn2  | INACT             | INACT              | Special pattern 4 | Special pattern 5 | Special pattern 6 | Special pattern 7 | Note 1    | Note 2    |  |  |  |
| TOSn3  | INACT             | Special pattern 0  | Special pattern 1 | Special pattern 2 | Special pattern 3 | INACT             | Note 1    | Note 2    |  |  |  |
| TOSn4  | Special pattern 6 | Special pattern 7  | INACT             | INACT             | Special pattern 4 | Special pattern 5 | Note 1    | Note 2    |  |  |  |
| TOSn5  | Special pattern 3 | INACT              | INACT             | Special pattern 0 | Special pattern 1 | Special pattern 2 | Note 1    | Note 2    |  |  |  |
| TOSn6  | Special pattern 4 | Special pattern 5  | Special pattern 6 | Special pattern 7 | INACT             | INACT             | Note 1    | Note 2    |  |  |  |



Pattern switch order

#### Normal rotation:TSnOPT4 register: TSnSOC = 0, TSnARD signal or TSnPSC = 0, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 1

|        |                      |                      |                   | $\longrightarrow$    |                   | Pattern           | n switch or | der       |  |  |
|--------|----------------------|----------------------|-------------------|----------------------|-------------------|-------------------|-------------|-----------|--|--|
| Output | TSnOPF2 to TSnOPF0   |                      |                   |                      |                   |                   |             |           |  |  |
| pin    | [1, 0, 1]            | [1, 0, 0]            | [1, 1, 0]         | [0, 1, 0]            | [0, 1, 1]         | [0, 0, 1]         | [0, 0, 0]   | [1, 1, 1] |  |  |
| TOSn1  | INACT                | INACT                | Special pattern 0 | Special<br>pattern 1 | Special pattern 2 | Special pattern 3 | Note 1      | Note 2    |  |  |
| TOSn2  | Special pattern 5    | Special pattern 6    | Special pattern 7 | INACT                | INACT             | Special pattern 4 | Note 1      | Note 2    |  |  |
| TOSn3  | Special pattern 2    | Special pattern 3    | INACT             | INACT                | Special pattern 0 | Special pattern 1 | Note 1      | Note 2    |  |  |
| TOSn4  | INACT                | Special pattern 4    | Special pattern 5 | Special pattern 6    | Special pattern 7 | INACT             | Note 1      | Note 2    |  |  |
| TOSn5  | Special pattern 0    | Special<br>pattern 1 | Special pattern 2 | Special pattern 3    | INACT             | INACT             | Note 1      | Note 2    |  |  |
| TOSn6  | Special<br>pattern 7 | INACT                | INACT             | Special pattern 4    | Special pattern 5 | Special pattern 6 | Note 1      | Note 2    |  |  |

**Note 1.** INACT if no change from the initial value. If the value is changed from any value to [0, 0, 0], output remains the level before the change.

2. Output remains the level before the change.

**Caution** Special pattern 3 and special pattern 4 cannot be active simultaneously. Special pattern 0 and special pattern 7 cannot be active simultaneously either. The simultaneous active setting results in the following operations.

- 1. Only TOSn1, TOSn3, and TOSn5 are active during the simultaneous active period if TOSn1, TOSn3, and TOSn5 become active prior to TOSn2, TOSn4, and TOSn6.
- 2. Only TOSn2, TOSn4, and TOSn6 are active during the simultaneous active period if TOSn2, TOSn4, and TOSn6 become active prior to TOSn1, TOSn3, and TOSn5.
- **3.** Only TOSn1, TOSn3, and TOSn5 are active during the simultaneous active period if TOSn1, TOSn3, TOSn5, and TOSn2, TOSn4, TOSn6 become active simultaneously.
- Note 1. Special patterns 0 to 7: Special pattern output by TSnCCR0 to TSnCCR3, TSnPAT0, and TSnPAT1 registers
  - 2. INACT: Inactive level output



## Chapter 17

## Reverse rotation: TSnOPT4 register: TSnSOC = 0, TSnARD signal or TSnPSC = 1, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 0

| Output |                   |                   | T                 | SnOPF2 to TS      | SnOPF0            |                   |           |           |
|--------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-----------|-----------|
| pin    | [1, 0, 1]         | [1, 0, 0]         | [1, 1, 0]         | [0, 1, 0]         | [0, 1, 1]         | [0, 0, 1]         | [0, 0, 0] | [1, 1, 1] |
| TOSn1  | Special pattern 2 | Special pattern 1 | Special pattern 0 | INACT             | INACT             | Special pattern 3 | Note 1    | Note 2    |
| TOSn2  | INACT             | INACT             | Special pattern 7 | Special pattern 6 | Special pattern 5 | Special pattern 4 | Note 1    | Note 2    |
| TOSn3  | INACT             | Special pattern 3 | Special pattern 2 | Special pattern 1 | Special pattern 0 | INACT             | Note 1    | Note 2    |
| TOSn4  | Special pattern 5 | Special pattern 4 | INACT             | INACT             | Special pattern 7 | Special pattern 6 | Note 1    | Note 2    |
| TOSn5  | Special pattern 0 | INACT             | INACT             | Special pattern 3 | Special pattern 2 | Special pattern 1 | Note 1    | Note 2    |
| TOSn6  | Special pattern 7 | Special pattern 6 | Special pattern 5 | Special pattern 4 | INACT             | INACT             | Note 1    | Note 2    |

#### Pattern switch order



Pattern switch order

## Reverse rotation: TSnOPT4 register: TSnSOC = 0, TSnARD signal or TSnPSC = 1, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 1

| Output |                   |                   | Т                    | SnOPF2 to TS      | SnOPF0            |                   |           |           |
|--------|-------------------|-------------------|----------------------|-------------------|-------------------|-------------------|-----------|-----------|
| pin    | [1, 0, 1]         | [1, 0, 0]         | [1, 1, 0]            | [0, 1, 0]         | [0, 1, 1]         | [0, 0, 1]         | [0, 0, 0] | [1, 1, 1] |
| TOSn1  | INACT             | INACT             | Special pattern 3    | Special pattern 2 | Special pattern 1 | Special pattern 0 | Note 1    | Note 2    |
| TOSn2  | Special pattern 6 | Special pattern 5 | Special pattern 4    | INACT             | INACT             | Special pattern 7 | Note 1    | Note 2    |
| TOSn3  | Special pattern 1 | Special pattern 0 | INACT                | INACT             | Special pattern 3 | Special pattern 2 | Note 1    | Note 2    |
| TOSn4  | INACT             | Special pattern 7 | Special pattern 6    | Special pattern 5 | Special pattern 4 | INACT             | Note 1    | Note 2    |
| TOSn5  | Special pattern 3 | Special pattern 2 | Special<br>pattern 1 | Special pattern 0 | INACT             | INACT             | Note 1    | Note 2    |
| TOSn6  | Special pattern 4 | INACT             | INACT                | Special pattern 7 | Special pattern 6 | Special pattern 5 | Note 1    | Note 2    |

**Note 1. INACT** if no change from the initial value. If the value is changed from any value to [0, 0, 0], output remains the level before the change.

2. Output remains the level before the change.

**Caution** Special pattern 3 and special pattern 4 cannot be active simultaneously. Special pattern 0 and special pattern 7 cannot be active simultaneously either. The simultaneous active setting results in the following operations.

- 1. Only TOSn1, TOSn3, and TOSn5 are active during the simultaneous active period if TOSn1, TOSn3, and TOSn5 become active prior to TOSn2, TOSn4, and TOSn6.
- 2. Only TOSn2, TOSn4, and TOSn6 are active during the simultaneous active period if TOSn2, TOSn4, and TOSn6 become active prior to TOSn1, TOSn3, and TOSn5.
- **3.** Only TOSn1, TOSn3, and TOSn5 are active during the simultaneous active period if TOSn1, TOSn3, TOSn5, and TOSn2, TOSn4, TOSn6 become active simultaneously.
- Note 1. Special patterns 0 to 7:Special pattern output by TSnCCR0 to TSnCCR3, TSnPAT0, and TSnPAT1 registers
  - 2. INACT: Inactive level output



## • When using 180° excitation function

TSnOPT4 register: TSnSOC = 0, TSnOPT5 register: TSnADC = 1, TSnPOT = 1, TSnOPT7 register: TSnIDC = 0

| Output pin | TSnOPF2 to TSnOPF0 |           |           |           |           |           |           |           |  |  |  |
|------------|--------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|--|--|--|
| output pin | [1, 0, 1]          | [1, 0, 0] | [1, 1, 0] | [0, 1, 0] | [0, 1, 1] | [0, 0, 1] | [0, 0, 0] | [1, 1, 1] |  |  |  |
| TOSn1      | ACT                | ACT       | ACT       | INACT     | INACT     | INACT     | Note 1    | Note 2    |  |  |  |
| TOSn2      | INACT              | INACT     | INACT     | ACT       | ACT       | ACT       | Note 1    | Note 2    |  |  |  |
| TOSn3      | INACT              | INACT     | ACT       | ACT       | ACT       | INACT     | Note 1    | Note 2    |  |  |  |
| TOSn4      | ACT                | ACT       | INACT     | INACT     | INACT     | ACT       | Note 1    | Note 2    |  |  |  |
| TOSn5      | ACT                | INACT     | INACT     | INACT     | ACT       | ACT       | Note 1    | Note 2    |  |  |  |
| TOSn6      | INACT              | ACT       | ACT       | ACT       | INACT     | INACT     | Note 1    | Note 2    |  |  |  |

TSnOPT4 register: TSnSOC = 0, TSnOPT5 register: TSnADC = 1, TSnPOT = 1, TSnOPT7 register: TSnIDC = 1

| Output pin | TSnOPF2 to TSnOPF0 |           |           |           |           |           |           |           |  |  |
|------------|--------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|--|--|
| Output pin | [1, 0, 1]          | [1, 0, 0] | [1, 1, 0] | [0, 1, 0] | [0, 1, 1] | [0, 0, 1] | [0, 0, 0] | [1, 1, 1] |  |  |
| TOSn1      | INACT              | INACT     | INACT     | ACT       | ACT       | ACT       | Note 1    | Note 2    |  |  |
| TOSn2      | ACT                | ACT       | ACT       | INACT     | INACT     | INACT     | Note 1    | Note 2    |  |  |
| TOSn3      | ACT                | ACT       | INACT     | INACT     | INACT     | ACT       | Note 1    | Note 2    |  |  |
| TOSn4      | INACT              | INACT     | ACT       | ACT       | ACT       | INACT     | Note 1    | Note 2    |  |  |
| TOSn5      | INACT              | ACT       | ACT       | ACT       | INACT     | INACT     | Note 1    | Note 2    |  |  |
| TOSn6      | ACT                | INACT     | INACT     | INACT     | ACT       | ACT       | Note 1    | Note 2    |  |  |

**Note 1.** INACT if no change from the initial value. If the value is changed from any value to [0, 0, 0], output remains the level before the change.

- 2. Output remains the level before the change.
- 3. ACT: Active level output
- 4. INACT: Inactive level output



## (b) Input pattern change order detection

Changes in the pattern (normal rotation/reverse rotation) input to the TAPTSn[2:0] pins are detected by the TSnTSF flag from the first change of the TAPTSn[2:0] pins from the time when TSnCE = 1 is set.



Figure 17-2 Detection example of change in pattern (normal rotation/reverse rotation) Input to TAPTSn[2:0] Pins



The TSnOPT6 register is a 16-bit register that controls each flag of timer Sn.

Access These registers can be read or written with a 16-bit, 8-bit, or 1-bit manipulation instruction.

TSnOPT6H enables access to the higher 8 bits of the TSnOPT6 register and TSnOPT6L enables access to the lower 8 bits of the TSnOPT6 register.

Address TS0OPT6: FFFF5A4<sub>H</sub> TS0OPT6H: FFFF5A5<sub>H</sub> TS0OPT6L: FFFF5A4<sub>H</sub> TS1OPT6: FFFF5E4<sub>H</sub> TS1OPT6H: FFFF5E5<sub>H</sub> TS1OPT6L: FFFF5E4<sub>H</sub>

Initial Value 0000<sub>H</sub>. This registers is cleared by any reset, or when TSnCTL0.TSnCE is set to 0.

|          | 15     | 14     | 13     | 12     | 11     | 10     | 9      | 8      |
|----------|--------|--------|--------|--------|--------|--------|--------|--------|
| TSnOPT3  | 0      | 0      | 0      | 0      | 0      | 0      | 0      | TSnPPF |
|          | R      | R      | R      | R      | R      | R      | R      | R/W    |
|          | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|          | TSnPTF | TSnTDF | TSnNDF | TSnPRF | TSnPEF | TSnTBF | TSnSUF | TSnRSF |
|          | R/W    |
|          |        |        |        |        |        |        |        |        |
|          | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| TSnOPT6H | 0      | 0      | 0      | 0      | 0      | 0      | 0      | TSnPPF |
|          | R      | R      | R      | R      | R      | R      | R      | R/W    |
|          |        |        |        |        |        |        |        |        |
|          | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| TSnOPT6L | TSnPTF | TSnTDF | TSnNDF | TSnPRF | TSnPEF | TSnTBF | TSnSUF | TSnRSF |
|          | R/W    |

Note Refer to "Flags" on page 716 for detailed information on each flag function.

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|-----------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 8               | TSnPPF   | <ul> <li>This is a flag that compares input pattern (TAPTSn[2:0] pins) with output pattern (TOSn[6:1] pins) while the TSnOPT7.TSnPPC bit is set to 1, and detects the differences.</li> <li>0: Did not detect any phase difference between the TAPTSn[2:0] pins and TOSn[6:1] pins.</li> <li>1: Detected phase difference between the TAPTSn[2:0] pins and TOSn[6:1] pins.</li> <li>The TSnPPF flag is set to 1 when the input/output pattern difference is detected, and the warning interrupt (INTTSnWn) occurs. This flag can be cleared by writing 0.</li> <li>Note: 1. The TSnPPF flag is valid when the TSnOPT4.TSnSOC bit is set to 0, the TSnOPT5.TSnPOT bit is set to 1 or the TSnOPT7.TSnPPC bit is set to 1.</li> <li>2. The TSnPPF flag is valid in the 120° excitation mode and special 120° excitation mode.</li> </ul> |  |  |  |



| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|-----------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 7               | TSnPTF   | <ul> <li>This is a flag that detects abnormal toggle of the TAPTSn[2:0] pins when the value of the TSnOPT7.TSnPTC1 bit is 1.</li> <li>0: No detection of any abnormal toggle of the TAPTSn[2:0] pins.</li> <li>1: Detected abnormal toggle of the TAPTSn[2:0] pins.</li> <li>The TSnPTF flag is set to 1 when the TAPTSn[2:0] pins (TSnAEDO signal toggle) are changed three times or more during the trigger of the TSnSTCI0 signal, or when the TAPTSn[2:0] pins (TSnAEDO signal toggle) are changed three times or more during the trigger of the TSnSTCI0 signal, or when the TAPTSn[2:0] pins (TSnAEDO signal toggles) are changed three times or more during the trigger of the TSnSTCI1 signal. Then a warning interrupt (INTTSnWN) occurs. The flag can be cleared by writing 0.</li> <li>Note: 1. The TSnPTF flag is valid when the TSnOPT4.TSnSOC bit is set to 0, the TSnOPT5.TSnPOT bit is set to 1, or TSnOPT7.TSnPTC is set to 1.</li> <li>2. The TSnPTF flag is valid when the 180° excitation control function is used in the high-accuracy T-PWM mode, 120° excitation mode, or special 120° excitation mode.</li> </ul> |  |  |  |
| 6               | TSnTDF   | <ul> <li>This is a flag that detects the simultaneous trigger generation of the TSnSTCI0 signal and the TSnSTCI1 signal when the value of the TSnOPT7.TSnTDC bit is 1.</li> <li>0: The triggers of the TSnSTCI0 signal and the TSnSTCI1 signal do not simultaneously occur</li> <li>1: Detects the simultaneous occurrence of the TSnSTCI0 signal and TSnSTCI1 signal triggers.</li> <li>The TSnTDF is set to 1 when the simultaneously generated triggers of the TSnSTCI0 signal and the TSnSTCI1 signal are detected. Then the warning interrupt (INTTSnWN) is generated. The flag can be cleared by writing 0.</li> <li>Note: 1. The TSnTDF flag is valid when the TSnOPT4.TSnSOC bit is set to 0, the TSnOPT5.TSnPOT bit is set to1 or the TSnOPT7.TSnTDC bit is set to 1.</li> <li>2. The TSnTDF flag is valid when the 180° excitation control function is used in the high-accuracy T-PWM mode, 120° excitation mode, or special 120° excitation mode.</li> </ul>                                                                                                                                                                  |  |  |  |
| 5               | TSnNDF   | <ul> <li>This is a flag that detects noise generation at the TAPTSn[2:0] pins.</li> <li>0: No noise generated due to simultaneous change of 2 or more pins of the TAPTSn[2:0] pins.</li> <li>1: Detected noise generation due to simultaneous change of 2 or more pins of the TAPTSn[2:0] pins.</li> <li>The TSnNDF flag is set to 1 when simultaneous value changes of 2 or more pins of the TAPTSn[2:0] pins are detected. Then the warning interrupt (INTTSnWN) occurs. The flag can be cleared by writing 0.</li> <li>Note: The TSnNDF flag is valid when the 180° excitation control function is used ir the high-accuracy T-PWM mode, 120° excitation mode, or special 120° excitation mode.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| 4               | TSnPRF   | <ul> <li>This is a flag that detects the inversion of the input order of the TAPTSn[2:0] pins.</li> <li>0: The input order of TAPTSn[2:0] pins is not inverted.</li> <li>1: The input order of TAPTSn[2:0] pins is inverted.</li> <li>The TSnPRF flag is set to 1 at the change timing of the TSnOPT5.TSnTSF bit and a warning interrupt (INTTSnWN) then occurs. The flag can be cleared by writing 0.</li> <li>Detection is possible from the timing of the second TAPTSn[2:0] pins change after the TSnCTL0.TSnCE bit is set to 1.</li> <li>Note: The TSnPRF flag is valid when using the 180° excitation control function in the high-accuracy T-PWM mode, 120° excitation mode, or 120° excitation mode</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |

# Table 17-15 TSnOPT6 register contents (2/3)



| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|-----------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 3               | TSnPEF   | This is a flag that detects [0, 0, 0] or [1, 1, 1] input to the TAPTSn[2:0] pins.<br>0: No input of [0, 0, 0] or [1, 1, 1] to the TAPTSn2 to TAPTSn0 pins.<br>1: [0, 0, 0] or [1, 1, 1] input to the TAPTSn2 to TAPTSn0 pins.                                                                                                                                                                                      |  |  |  |
|                 |          | The TSnPEF flag is set to 1 when [0, 0, 0] or [1, 1, 1] input to TAPTSn[2:0] pins is detected and a warning interrupt (INTTSnWN) then occurs. The flag can be cleared by writing 0.                                                                                                                                                                                                                                |  |  |  |
|                 |          | <b>Note:</b> The TSnPEF flag is valid when the 180° excitation control function is used in the high-accuracy T-PWM mode, 120° excitation mode, or special 120° excitation mode.                                                                                                                                                                                                                                    |  |  |  |
| 2               | TSnTBF   | This is a flag that detects both of the positive phase and negative phase turns to be active simultaneously when any bit from the TSnIOC4.TSnTBA[2:0] bits is set to 1.<br>0: Positive phase and negative phase are not active simultaneously.<br>1: Positive phase and negative phase become active simultaneously.                                                                                               |  |  |  |
|                 |          | The TSnTBF flag is set to 1 when simultaneous active of any of positive phase (TOSn1, TOSn3, TOSn5) and any of negative phase (TOSn2, TOSn4, TOSn6) is detected. Then the error interrupt (INTTSnER) occurs. The flag can be cleared by writing 0.<br>Simultaneous active is not detected when TSnTBA[2:0] = [0, 0, 0].                                                                                            |  |  |  |
| 1               | TSnSUF   | This is a flag that detects count up/down of 16-bit sub-counter.<br>0: Sub-counter performing count-up operation.<br>1: Sub-counter performing count-down operation.                                                                                                                                                                                                                                               |  |  |  |
|                 |          | For the TSnSUF flag detection, count-up is the count from 0000H to (TSnCCR0 register value – 0002H), and count-down is the count from the TSnCCR0 register value to 0002H of sub-counter count operation.                                                                                                                                                                                                          |  |  |  |
|                 |          | <ul><li>Note: 1. TSnSUF flag is read only.</li><li>2. TSnSUF flag is valid only in the high-accuracy T-PWM mode.</li></ul>                                                                                                                                                                                                                                                                                         |  |  |  |
|                 | TO-DOF   |                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| 0               | TSnRSF   | <ul> <li>This is a flag that shows whether or not there is a reload request.</li> <li>0: No reload request, or reload completed<br/>Enable write access to the TSnCCR0 to TSnCCR5, TSnOPT1, TSnDTC0,<br/>TSnDTC1, TSnPAT0, and TSnPAT1 registers.</li> <li>1: Reload request issued<br/>(Disable write access to the TSnCCR0 to TSnCCR5, TSnOPT1, TSnDTC0,<br/>TSnDTC1, TSnPAT0, and TSnPAT1 registers)</li> </ul> |  |  |  |
|                 |          | The TSnRSF flag indicates that the next transfer data is held in registers TSnCCR0<br>TSnCCR5, TSnOPT1, TSnDTC0, TSnDTC1, TSnPAT0, and TSnPAT1.<br>The TSnRSF flag is set to 1 by writing to the TSnCCR1 register and cleared to 0 up<br>reload completion.                                                                                                                                                        |  |  |  |
|                 |          | <b>Caution:</b> The written value of the register may be undefined if writing to the TSnCCR0 to TSnCCR5, TSnOPT1, TSnDTC0, TSnDTC1, TSnPAT0, TSnPAT1 registers and the reload timing conflict while TSnRSF = 1.                                                                                                                                                                                                    |  |  |  |

## Table 17-15 TSnOPT6 register contents (3/3)



## (13) Timer Sn option register 7 (TSnOPT7)

The TSnOPT7 register is an 8-bit register that detects the abnormal timer output and controls switching of the timer output.

- Access This register can be read/written in 8-bit or 1-bit units.
- Address TS0OPT7: FFFFF587<sub>H</sub> TS1OPT7: FFFFF5C7<sub>H</sub>

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

| 7 | 6 | 5      | 4      | 3      | 2       | 1       | 0      |
|---|---|--------|--------|--------|---------|---------|--------|
| 0 | 0 | TSnIDC | TSnPPC | TSnTDC | TSnPTC1 | TSnPTC0 | TSnTOS |
| R | R | R/W    | R/W    | R/W    | R/W     | R/W     | R/W    |

| Table 17-16 | TSnOPT7 register contents ( | 1/2) |
|-------------|-----------------------------|------|
|-------------|-----------------------------|------|

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                         |   |   |                        |  |  |
|-----------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|------------------------|--|--|
| 5               | TSnIDC   | Sets the output pattern of TOSn1 to TOSn6 by combination of the TSnOPT5.TSnTSF bit , the TSnOPT4.TSnPSC bit and the TSnARD signal.<br>Refer to <i>"Timer output order in each mode and function" on page 654</i> and <i>"Timer output pattern in each mode and function" on page 671</i> for the output pattern. |   |   |                        |  |  |
|                 |          | TSnOPT4.         TSnOPT5.         TSnOPT5.           TSnSOC         TSnPOT         TSnPSS         Rotation Direction                                                                                                                                                                                             |   |   |                        |  |  |
|                 |          | 1                                                                                                                                                                                                                                                                                                                | - | - | -                      |  |  |
|                 |          | 0                                                                                                                                                                                                                                                                                                                | 0 | - | TSnTSF flag            |  |  |
|                 |          | 0                                                                                                                                                                                                                                                                                                                | 1 | 0 | Input signal to TSnARD |  |  |
|                 |          | 0                                                                                                                                                                                                                                                                                                                | 1 | 1 | TSnPSC bit             |  |  |
|                 |          | Caution: The TSnIDC bit is valid in the 120° excitation mode, special 120° excitation mode, 180° excitation control, and software output control. 0 must be set in any other mode.                                                                                                                               |   |   |                        |  |  |
| 4               | TSnPPC   | Enables/disables input/output pattern difference detection (TSnOPT6.TSnPPF flag,<br>warning interrupt (INTTSnWN)).<br>0: Disable input/output pattern difference detection<br>1: Enable input/output pattern difference detection                                                                                |   |   |                        |  |  |
|                 |          | Note: TSnPPC = 0 disables the TSnPPF bit detection and the warning interrupt<br>(INTTSnWN). Also, input/output pattern difference detection flag<br>(TSnOPT6.TSnPPF bit ) is not controlled.                                                                                                                     |   |   |                        |  |  |
| 3               | TSnTDC   | Controls the simultaneous trigger detection of the TSnSTCI0 and TSnSTCI1 signals (TSnOPT6.TSnTDF flag, warning interrupt (INTTSnWN)).<br>0: Disables simultaneous trigger detection of the TSnSTCI0 and TSnSTCI1 signals.<br>1: Enables simultaneous trigger detection of the TSnSTCI0 and TSnSTCI1 signals.     |   |   |                        |  |  |
|                 |          | <b>Note:</b> TSnTDC = 0 disables the warning interrupt (INTTSnWN). Also, simultaneous trigger detection flag (TSnOPT6.TSnTDF bit) is not controlled.                                                                                                                                                             |   |   |                        |  |  |



| Bit<br>position | Bit name            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                      |                                                                                                                                                                                                   |  |  |
|-----------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 2, 1            | TSnPTC1,<br>TSnPTC0 | Controls detection of abnormal toggle of the TAPTSn[2:0] pins (TSnOPT6.TSnPTF flag, warning interrupt (INTTSnWN)).                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                      |                                                                                                                                                                                                   |  |  |
|                 |                     | TSnPTC1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | TSnPTC0                                                                                                                                                                                              | Operations                                                                                                                                                                                        |  |  |
|                 |                     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0/1                                                                                                                                                                                                  | Don't detect abnormal toggle of the TAPTSn[2:0] pins.                                                                                                                                             |  |  |
|                 |                     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0                                                                                                                                                                                                    | <ul> <li>Detect abnormal toggle of the TAPTSn[2:0] pins.</li> <li>Don't change timer output switch method by abnormal toggle detection (change of the TSnOPT5.TSnPOT bit from 1 to 0).</li> </ul> |  |  |
|                 |                     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | <ul> <li>Detect abnormal toggle of the TAPTSn[2:0] pins.</li> <li>Change the timer output switch method through abnormal toggle detection (change of the TSnOPT5.TSnPOT bit from 1 to 0).</li> </ul> |                                                                                                                                                                                                   |  |  |
|                 |                     | When the TSnPTC1 bit is set to 1, a warning interrupt (INTTSnWN) occurs when<br>three or more toggles (abnormal toggles) are detected by the TAPTSn[2:0] pin inputs<br>during the trigger of the TSnSTCl1 or TSnSTCl0 signal input. Then the TAPTSn[2:0]<br>pin abnormal toggle detection flag (TSnPTF) is set to 1. The normal rotation or<br>reverse rotation can be detected after the first change of the TAPTSn[2:0] pins after<br>TSnCE = 1 is set.<br>For details, refer to <i>"Input pattern change order detection" on page 679</i> . |                                                                                                                                                                                                      |                                                                                                                                                                                                   |  |  |
| 0               | TSnTOS              | Controls the TOSn0 pin output switch.<br>0: Outputs count up/down flag of 16-bit counter to TOSn0 pin.<br>1: Outputs count up/down flag of 16-bit sub-counter to TOSn0 pin.<br>When the TSnTOS bit is 0, the TSnOPT0 register is output to the TOSn0 pin. When<br>the TSnTOS bit is 1, the TSnOPT6.TSnSUF bit status is output to the TOSn0 pin.                                                                                                                                                                                               |                                                                                                                                                                                                      |                                                                                                                                                                                                   |  |  |
|                 |                     | Note: The TSnTOS bit is valid only in the high-accuracy T-PWM mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                      |                                                                                                                                                                                                   |  |  |

# Table 17-16 TSnOPT7 register contents (2/2)



## (14) Timer Sn pattern register 0 (TSnPAT0)

The TSnPAT0 register is a 16-bit register that controls output patterns in the special 120° excitation mode and special pattern output mode..

Access This register can be read/written in 16-bit units only. Do not read/write this register in 8-bit or 1-bit units.

| Address | TS0PAT0: | FFFFF596 <sub>H</sub> |
|---------|----------|-----------------------|
|         | TS1PAT0: | FFFFF5D6 <sub>H</sub> |

Initial Value 0000<sub>H</sub>. This register is cleared by any reset.

| 15  | 14                | 13        | 12  | 11                | 10  | 9   | 8   |  |
|-----|-------------------|-----------|-----|-------------------|-----|-----|-----|--|
|     | Special           | oattern 3 |     | Special pattern 2 |     |     |     |  |
| R/W | R/W               | R/W       | R/W | R/W               | R/W | R/W | R/W |  |
| 7   | 6                 | 5         | 4   | 3                 | 2   | 1   | 0   |  |
|     | Special pattern 1 |           |     | Special pattern 0 |     |     |     |  |
| R/W | R/W               | R/W       | R/W | R/W               | R/W | R/W | R/W |  |

Caution The TSnPAT0 register setting must be executed while the timer Sn operation is stopped (when the TSnCE bit of the TSnCTL0 register is set to 0). In order to change the value of the TSnPAT0 register during the timer Sn operation (when the value of the TSnCE bit of the TSnCTL0 register is 1), do so after setting the TSnCE bit to 1 and waiting for 1 cycle of the 16-bit counter to be completed.

#### Table 17-17 TSnPAT0 register contents

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                           |
|-----------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15 to 12        | -        | Controls the output pattern of special pattern 3 of the TOSn1, TOSn3, and TOSn5 pins in the special 120° excitation mode.<br>The output pattern of the TOSn3 pin is controlled in the special pattern output mode.<br><b>Note:</b> Refer to <i>Table 17-18 on page 686</i> for the output pattern. |
| 11 to 8         | -        | Controls the output pattern of special pattern 2 of the TOSn1, TOSn3, and TOSn5 pins in the special 120° excitation mode.<br>The output pattern of the TOSn2 pin is controlled in the special pattern output mode.<br><b>Note:</b> Refer to <i>Table 17-18 on page 686</i> for the output pattern. |
| 7 to 4          | -        | Controls the output pattern of special pattern 1 of the TOSn1, TOSn3, and TOSn5 pins in the special 120° excitation mode.<br>The output pattern of the TOSn1 pin is controlled in the special pattern output mode.<br><b>Note:</b> Refer to <i>Table 17-18 on page 686</i> for the output pattern. |
| 3 to 0          | -        | Controls output pattern of special pattern 0 of the TOSn1, TOSn3, and TOSn5 pins in the special 120° excitation mode.<br>The output pattern of the TOSn0 pin is controlled in the special pattern output mode.<br><b>Note:</b> Refer to <i>Table 17-18 on page 686</i> for the output pattern.     |



| TSnPAT0 register bit setting:                                                                                                   | Output level by match between TSnCCRm register and 16-bit counter |                                   |                                   |                                   |  |
|---------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|--|
| bits 15 to 12 (special pattern 3),<br>11 to 8 (special pattern 2),<br>7 to 4 (special pattern 1),<br>3 to 0 (special pattern 0) | Match with<br>TSnCCR3<br>register                                 | Match with<br>TSnCCR2<br>register | Match with<br>TSnCCR1<br>register | Match with<br>TSnCCR0<br>register |  |
| 0, 0, 0, 0                                                                                                                      | INACT <sup>Note 1</sup>                                           | INACT <sup>Note 1</sup>           | INACT <sup>Note 1</sup>           | INACT <sup>Note 1</sup>           |  |
| 0, 0, 0, 1                                                                                                                      | INACT                                                             | INACT                             | INACT                             | ACT                               |  |
| 0, 0, 1, 0                                                                                                                      | INACT                                                             | INACT                             | ACT                               | INACT                             |  |
| 0, 0, 1, 1                                                                                                                      | INACT                                                             | INACT                             | ACT                               | ACT                               |  |
| 0, 1, 0, 0                                                                                                                      | INACT                                                             | ACT                               | INACT                             | INACT                             |  |
| 0, 1, 0, 1                                                                                                                      | INACT                                                             | ACT                               | INACT                             | ACT                               |  |
| 0, 1, 1, 0                                                                                                                      | INACT                                                             | ACT                               | ACT                               | INACT                             |  |
| 0, 1, 1, 1                                                                                                                      | INACT                                                             | ACT                               | ACT                               | ACT                               |  |
| 1, 0, 0, 0                                                                                                                      | ACT                                                               | INACT                             | INACT                             | INACT                             |  |
| 1, 0, 0, 1                                                                                                                      | ACT                                                               | INACT                             | INACT                             | ACT                               |  |
| 1, 0, 1, 0                                                                                                                      | ACT                                                               | INACT                             | ACT                               | INACT                             |  |
| 1, 0, 1, 1                                                                                                                      | ACT                                                               | INACT                             | ACT                               | ACT                               |  |
| 1, 1, 0, 0                                                                                                                      | ACT                                                               | ACT                               | INACT                             | INACT                             |  |
| 1, 1, 0, 1                                                                                                                      | ACT                                                               | ACT                               | INACT                             | ACT                               |  |
| 1, 1, 1, 0                                                                                                                      | ACT                                                               | ACT                               | ACT                               | INACT                             |  |
| 1, 1, 1, 1                                                                                                                      | ACT <sup>Note 2</sup>                                             | ACT <sup>Note 2</sup>             | ACT <sup>Note 2</sup>             | ACT <sup>Note 2</sup>             |  |

## Table 17-18 Output Pattern Setting for TSnPAT0 Register

Note 1. Inactive level is output regardless of match with the TSnCCRm register.

2. Active level is output regardless of match with the TSnCCRm register.

- 3. ACT: Active level output
- 4. INACT: Inactive level output
- 5. m = 1 to 3



## (15) Timer Sn pattern register 1 (TSnPAT1)

The TSnPAT1 register is a 16-bit register that controls output patterns in the special 120° excitation mode and special pattern output mode.

Access This register can be read/written in 16-bit units only. Do not read/write this register in 8-bit or 1-bit units.

| Address | TS0PAT1: | FFFFF594 <sub>H</sub> |
|---------|----------|-----------------------|
|         | TS1PAT1: | FFFFF5D4 <sub>H</sub> |

Initial Value 0000<sub>H</sub>. This register is cleared by any reset.

| 15  | 14                | 13        | 12  | 11                | 10  | 9   | 8   |  |
|-----|-------------------|-----------|-----|-------------------|-----|-----|-----|--|
|     | Special           | oattern 7 |     | Special pattern 6 |     |     |     |  |
| R/W | R/W               | R/W       | R/W | R/W               | R/W | R/W | R/W |  |
| 7   | 6                 | 5         | 4   | 3                 | 2   | 1   | 0   |  |
|     | Special pattern 5 |           |     | Special pattern 4 |     |     |     |  |
| R/W | R/W               | R/W       | R/W | R/W               | R/W | R/W | R/W |  |

Caution The TSnPAT1 register setting must be executed while the timer Sn operation is stopped (when the TSnCE bit of the TSnCTL0 register is set to 0). In order to change the value of the TSnPAT0 register during the timer Sn operation (when the value of the TSnCE bit of the TSnCTL0 register is 1), do so after setting the TSnCE bit to 1 and waiting for 1 cycle of the 16-bit counter to be completed.

#### Table 17-19 TSnPAT1 register contents

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                     |
|-----------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15 to 12        | -        | Controls the output pattern of special pattern 7 of the TOSn2, TOSn4, and TOSn6 pins in the special 120° excitation mode.<br>Output pattern of the TOSn7 pin is controlled in the special pattern output mode.<br><b>Note:</b> Refer to <i>Table on page 688</i> for the output pattern.     |
| 11 to 8         | -        | Controls the output pattern of special pattern 6 of the TOSn2, TOSn4, and TOSn6 pins in the special 120° excitation mode.<br>The output pattern of the TOSn6 pin is controlled in the special pattern output mode.<br><b>Note:</b> Refer to <i>Table on page 688</i> for the output pattern. |
| 7 to 4          | -        | Controls the output pattern of special pattern 5 of the TOSn2, TOSn4, and TOSn6 pins in the special 120° excitation mode.<br>The output pattern of the TOSn5 pin is controlled in the special pattern output mode.<br><b>Note:</b> Refer to <i>Table on page 688</i> for the output pattern. |
| 3 to 0          | -        | Controls the output pattern of special pattern 4 of the TOSn2, TOSn4, and TOSn6 pins in the special 120° excitation mode.<br>The output pattern of TOSn4 pin is controlled in the special pattern output mode.<br><b>Note:</b> Refer to <i>Table on page 688</i> for the output pattern.     |



| TSnPAT1 register bit setting:<br>bits 15 to 12 (special pattern 7),                       | Output level based on match between the tsnccrm register and 16-bit counter |                                   |                                   |                                   |  |
|-------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|--|
| 11 to 8 (special pattern 6),<br>7 to 4 (special pattern 5),<br>3 to 0 (special pattern 4) | Match with<br>TSnCCR3<br>register                                           | Match with<br>TSnCCR2<br>register | Match with<br>TSnCCR1<br>register | Match with<br>TSnCCR0<br>register |  |
| 0, 0, 0, 0                                                                                | INACT <sup>Note 1</sup>                                                     | INACT <sup>Note 1</sup>           | INACT <sup>Note 1</sup>           | INACT <sup>Note 1</sup>           |  |
| 0, 0, 0, 1                                                                                | INACT                                                                       | INACT                             | INACT                             | ACT                               |  |
| 0, 0, 1, 0                                                                                | INACT                                                                       | INACT                             | ACT                               | INACT                             |  |
| 0, 0, 1, 1                                                                                | INACT                                                                       | INACT                             | ACT                               | ACT                               |  |
| 0, 1, 0, 0                                                                                | INACT                                                                       | ACT                               | INACT                             | INACT                             |  |
| 0, 1, 0, 1                                                                                | INACT                                                                       | ACT                               | INACT                             | ACT                               |  |
| 0, 1, 1, 0                                                                                | INACT                                                                       | ACT                               | ACT                               | INACT                             |  |
| 0, 1, 1, 1                                                                                | INACT                                                                       | ACT                               | ACT                               | ACT                               |  |
| 1, 0, 0, 0                                                                                | ACT                                                                         | INACT                             | INACT                             | INACT                             |  |
| 1, 0, 0, 1                                                                                | ACT                                                                         | INACT                             | INACT                             | ACT                               |  |
| 1, 0, 1, 0                                                                                | ACT                                                                         | INACT                             | ACT                               | INACT                             |  |
| 1, 0, 1, 1                                                                                | ACT                                                                         | INACT                             | ACT                               | ACT                               |  |
| 1, 1, 0, 0                                                                                | ACT                                                                         | ACT                               | INACT                             | INACT                             |  |
| 1, 1, 0, 1                                                                                | ACT                                                                         | ACT                               | INACT                             | ACT                               |  |
| 1, 1, 1, 0                                                                                | ACT                                                                         | ACT                               | ACT                               | INACT                             |  |
| 1, 1, 1, 1                                                                                | ACT <sup>Note 2</sup>                                                       | ACT <sup>Note 2</sup>             | ACT <sup>Note 2</sup>             | ACT <sup>Note 2</sup>             |  |

## Table 17-20 Output pattern setting for TSnPAT1 register

Note 1. Inactive level is output regardless of match with the TSnCCRm register.

2. Active level is output regardless of match with the TSnCCRm register.

3. ACT: Active level output

4. INACT: Inactive level output

5. m = 1 to 3



## 17.4 Basic Operation

## 17.4.1 16-bit counter basic operation

The 16-bit counter basic operation is described below. Refer to *"Operation in Each Mode" on page 756* for details.

## (1) Count start operation

The 16-bit counter of timer Sn starts counting from the initial value FFFH<sup>Note</sup> in every mode except the high-accuracy T-PWM mode. Count-up operation is performed such as FFFFH, 0000H, 0001H, 0002H, 0003H ... For the high-accuracy T-PWM mode, refer to *"16-bit counter operation in high-accuracy T-PWM mode" on page 801*.

**Note** FFFEH in high-accuracy T-PWM mode.

## (2) Clear operation

The 16-bit counter is cleared to 0000H upon a match between the values of the 16-bit counter and compare register. Count operation from FFFFH to 0000H is not detected as clear operation immediately after count start or when overflow.

## (3) Overflow operation

Overflow of the 16-bit counter occurs at the timing of the switch from FFFFH to 0000H in the free-running mode. If overflow occurs, the TSnOVF bit of the TSnOPT0 register is set to 1 and an overflow interrupt (INTTSnOV) occurs. The overflow interrupt (INTTSnOV) does not occur immediately after count operation start or when the compare value is cleared by detecting match at FFFFH.

## (4) Counter read operation during count operation

Timer Sn can read the 16-bit counter value with the TSnCNT register during count operation.



## (5) Interrupt operation

The following interrupt signals are generated in timer Sn.

- INTTSnCC0: Functions as a TSnCCRn0 buffer register match interrupt.
- INTTSnCC1: Functions as a TSnCCRn1 buffer register match interrupt.
- INTTSnCC2: Functions as a TSnCCRn2 buffer register match interrupt.
- INTTSnCC3: Functions as a TSnCCRn3 buffer register match interrupt.
- INTTSnCC4: Functions as a TSnCCRn4 buffer register match interrupt.
- INTTSnCC5: Functions as a TSnCCRn5 buffer register match interrupt.
- INTTSnOD0: Functions as a peak interrupt at the S/W timing from count-up operation to count-down operation of the 16-bit counter.
- INTTSnOD: Functions as a trough interrupt at the S/W timing from countdown operation to count-up operation of the 16-bit counter.
- INTTSnOV: Functions as an overflow interrupt.
- INTTSnER: Functions as a positive/negative phase simultaneous active detection interrupt.
- INTTSnWN: Functions as each type warning detection interrupt.



## 17.4.2 Compare register rewriting

The reload function is valid in the PWM mode, triangular-wave PWM mode, high-accuracy T-PWM mode (when the TSnCMS bit is 0), PWM mode with dead time, external trigger pulse output mode, 120° excitation mode, special 120° excitation mode, and special pattern output mode. Reload setting in any other mode than above is invalid.

The compare registers and control registers with reload function are as follows.

- TSnCCR0 to TSnCCR5
- TSnOPT1
- TSnPAT0, TSnPAT1
- TSnDTC0, TSnDTC1

There are the following two modes for rewriting compare registers with the reload function.

- Anytime rewrite mode In the anytime rewrite mode, writing to each compare register during update operation by each independent compare register enables write access value updating anytime.
- Reload mode (batch rewrite function) Reload is enabled by writing to the TSnCCR1 register (reload request flag TSnRSF is set) and then the values of the target registers are updated simultaneously at the next reload timing. The reload timing is the peak/trough timing of a 16-bit counter. Control is executed by the TSnRTE and TSnRBE bits of the TSnOPT1 register, respectively. Reload is not enabled even if writing to any other register than TSnCCR1.

Rewriting of compare registers is possible with DMA transfer.

The DMA transfer can start at each register. The address is incremented after each DMA transfer and always stops after the DMA transfer to the TSnCCR1 register.

Table 17-21 shows the order of the DMA transfers.

Table 17-21 Timer S DMA transfer (1/2)

| Timer | Address                             | Register name                     | DMA transfer order |                 |
|-------|-------------------------------------|-----------------------------------|--------------------|-----------------|
|       | FFFFFB40H                           | TS0OPT1A                          |                    |                 |
|       | FFFFFB42H                           | TS0DTC1A                          |                    |                 |
|       | FFFFB44H                            | TS0DTC0A                          |                    |                 |
|       | FFFFB46H                            | TS0CCR5A                          |                    |                 |
|       | FFFFFB48H                           | TS0CCR4A                          |                    |                 |
| TMS0  | FFFFFB4AH                           | TS0CCR3B                          |                    |                 |
|       | FFFFB4CH/<br>FFFFF594H <sup>a</sup> | TS0CCR2B/<br>TS0PAT1 <sup>a</sup> |                    | Start registers |
|       | FFFFB4EH/<br>FFFFF596 <sup>a</sup>  | TS0CCR1B/<br>TS0PAT0 <sup>a</sup> |                    |                 |
|       | FFFFB50H                            | TS0CCR0A                          |                    |                 |
|       | FFFFB52H                            | TS0CCR3A                          |                    |                 |
|       | FFFFB54H                            | TS0CCR2A                          |                    |                 |
|       | FFFFB56H                            | TS0CCR1A                          | $\downarrow$       | End register    |





## Table 17-21 Timer S DMA transfer (2/2)

| Timer | Address                            | Register name                     | DMA transfer order |                 |
|-------|------------------------------------|-----------------------------------|--------------------|-----------------|
|       | FFFFBC0H                           | TS10PT1A                          |                    |                 |
|       | FFFFBC2H                           | TS1DTC1A                          |                    |                 |
|       | FFFFBC4H                           | TS1DTC0A                          |                    |                 |
|       | FFFFBC6H                           | TS1CCR5A                          |                    |                 |
|       | FFFFBC8H                           | TS1CCR4A                          |                    |                 |
|       | FFFFBCAH                           | TS1CCR3B                          |                    |                 |
| TMS1  | FFFFBCCH/<br>FFFFF5D4 <sup>a</sup> | TS1CCR2B/<br>TS1PAT1 <sup>a</sup> |                    | Start registers |
|       | FFFFBCEH/<br>FFFFF5D6 <sup>a</sup> | TS1CCR1B/<br>TS1PAT0 <sup>a</sup> |                    |                 |
|       | FFFFBD0H                           | TS1CCR0A                          |                    |                 |
|       | FFFFBD2H                           | TS1CCR3A                          |                    |                 |
|       | FFFFBD4H                           | TS1CCR2A                          |                    |                 |
|       | FFFFBD6H                           | TS1CCR1A                          | $\downarrow$       | End register    |

a) If Timer Sn is operated in high-accuracy T-PWM mode, TSnCCR[2:1]B is used, otherwise TSnPAT[1:0]

Refer to *"Interrupt Thinning out Function" on page 735* for details on the interrupt thinning out function through the TSnOPT1 register setting.

#### Table 17-22 Rewrite timing by mode

| Mode                               | Rewrite timing                           |
|------------------------------------|------------------------------------------|
| Interval timer mode                | Anytime rewrite                          |
| External event count mode          | Anytime rewrite                          |
| External trigger pulse output mode | Reload <sup>Note 3</sup>                 |
| One-shot pulse mode                | Anytime rewrite                          |
| PWM mode                           | Reload                                   |
| Free-running mode                  | Anytime rewrite                          |
| Triangular-wave PWM mode           | Reload <sup>Note 1</sup>                 |
| High-accuracy T-PWM mode           | Anytime rewrite/Reload <sup>Note 2</sup> |
| PWM mode with dead time            | Reload                                   |
| 120° excitation mode               | Reload                                   |
| Special 120° excitation mode       | Reload                                   |
| Special pattern output mode        | Reload                                   |

## Note 1. Rewriting only in trough interrupt

- 2. Setting with the TSnCMS bit of the TSnOPT0 register
- 3. Reload thinning out function disabled



#### (1) Anytime rewrite mode

In the anytime rewrite mode, the value written to each compare register is immediately transferred to the internal buffer register as the comparison target for the counter value.

The value is written to the compare registers (such as TSnCCR0 to TSnCCR5) and then transferred to the internal buffer register in 4 clocks ( $f_{TMSn}$ ). However, only for the TSnCCR1 register, transfer timing is in 5 clocks ( $f_{TMSn}$ ) because of its 3-step buffer composition.

**Note** In the high-accuracy T-PWM mode, the mode is the anytime rewrite mode when the TSnCMS bit of the TSnOPT0 register is set to 1. The settings of the TSnIOE, TSnICE, TSnRDE, and TSnID4 to TSnID0 bits of the TSnOPT1 register are ignored.



Figure 17-3 Anytime rewrite timing (example in PWM mode)

- Note 1. D<sub>01</sub>, D<sub>02</sub>: TSnCCR0 register setting values (0000H to FFFFH) D<sub>11</sub>, D<sub>12</sub>: TSnCCR1 register setting values (0000H to FFFFH) D<sub>21</sub>: TSnCCR2 register setting value (0000H to FFFFH) D<sub>31</sub>: TSnCCR3 register setting value (0000H to FFFFH)
  - 2. Timing chart where interval timer mode is provided as an example
  - 3.  $\Delta$ : CPU write access



# (a) Caution on TSnCCR0 register rewriting in high-accuracy T-PWM mode

In the high-accuracy T-PWM mode, transfer to the TSnCCR0 buffer register is not executed if the TSnCCR0 register is rewritten in the anytime rewrite mode. The timing is shown below.



Figure 17-4 TSnCCR0 register rewrite timing in anytime rewrite mode (high-accuracy T-PWM mode)

Note d1: TSnDTC1 setting value

After rewriting of the TSnCCR0 register, the TSnCCR0 register value is transferred to the TSnCCR0 buffer register at the next peak/trough timing. The settings of the TSnIOE, TSnICE, TSnRDE, and TSnID4 to TSnID0 bits of the TSnOPT1 register are ignored because TSnCMS of TSnOPT0 is 1 (anytime rewrite mode).

# (b) Caution on rewriting in high-accuracy T-PWM mode for TSnCCR1 to TSnCCR3 registers



Rewriting during period <1> (rewriting before match detection)

When rewriting before match of the 16-bit counter value with the TSnCCR1 to TSnCCR3 values, the rewritten value is reflected immediately by detection of the match with the 16-bit counter value after rewriting.





If a value smaller than the 16-bit counter value is rewritten before a match, the match is not detected, so that the output waveform is as follows. TOSn1, TOSn3, and TOSn5 forcibly change to active and TOSn2, TOSn4, and TOSn6 to inactive at the peak even without detection.





Rewriting at period <2> (rewriting after match detection)

The timer output level does not change upon re-match after match detection if rewritten after match of the 16-bit counter value with the TSnCCR1 to TSnCCR3 register values.



- **Note 1.** The timer output level does not change upon rematch through rewriting after match detection.
  - 2. The timer output level changes from the first match after up/down switch.
  - 3. However, the interrupt output of INTTSnCC1 is match interrupt output.

Rewriting at period <3> (rewriting before match detection)

When rewriting before match of the 16-bit counter value with the TSnCCR1 to TSnCCR3 values, the rewritten value is reflected immediately by detection of the match with the 16-bit counter value after rewriting.



If a value larger than the 16-bit counter value is rewritten before match, match is not detected, so that the output waveform is as shown below. TOSn1, TOSn3, and TOSn5 forcibly change to inactive and TOSn2, TOSn4, and TOSn6 to active at the trough even without match detection.





Rewriting at period <4> (rewriting after match detection)

The timer output level does not change upon re-match after match detection if rewritten after match of the 16-bit counter value with the values of the TSnCCR1 to TSnCCR3 registers.



- **Note 1.** The timer output level does not change even upon re-match through rewriting after match detection.
  - 2. The timer output level changes from the first match after up/down switch.
  - 3. However, the interrupt output of INTTSnCC1 is match interrupt output.



## (2) Reload mode (batch rewrite function)

In the reload mode, the values written to the reload target registers (TSnCCR0 to TSnCCR5, TSnOPT1, TSnDTC0, TSnDTC1, TSnPAT0, and TSnPAT1) are transferred to each buffer register simultaneously at the reload timing. Reload target register value must be rewritten while the reload request flag (TSnRSF of the TSnOPT6 register) is 0.



Figure 17-5 Basic operation in reload mode (batch rewrite function) <example in PWM mode>

Caution The

The write access to the TSnCCR1 register includes the operation that enables reload. Therefore, do not rewrite any TSnCCR1 register value before rewriting the other TSnCCR registers.





Figure 17-6 Batch rewrite timing (1/2) (high-accuracy T-PWM mode)







## (a) Example of reload rewriting setting in each mode

The following is a setting example of the reload enable mode. Performing the settings listed in *Table 17-23 on page 700* results in reload. Reload does not occur in any other setting than this combination. Refer to *Table 17-10 on page 640* for details.

| Setting bit mode              | TSnCMS of<br>TSnOPT0<br>register | TSnRDE of<br>TSnOPT1<br>register | TSnICE of<br>TSnOPT1<br>register | TS0nRTE of<br>TSnOPT1<br>register | TSnIOE of<br>TSnOPT1<br>register | TSnRBE of<br>TSnOPT1<br>register |
|-------------------------------|----------------------------------|----------------------------------|----------------------------------|-----------------------------------|----------------------------------|----------------------------------|
| External trigger pulse output | 0                                | 0                                | ×                                | 1                                 | ×                                | ×                                |
| PWM mode                      | 0                                | 0                                | ×                                | 1                                 | ×                                | ×                                |
|                               | 0                                | 1                                | 1                                | 1                                 | ×                                | ×                                |
| Triangular-wave PWM           | 0                                | 0                                | ×                                | ×                                 | ×                                | 1                                |
|                               | 0                                | 1                                | ×                                | ×                                 | 1                                | 1                                |
| High-accuracy T-PWM           | 0                                | 0                                | ×                                | × <sup>Note 1</sup>               | ×                                | × <sup>Note 1</sup>              |
|                               | 0                                | 1                                | ×                                | ×                                 | 1                                | 1                                |
|                               | 0                                | 1                                | 1                                | 1                                 | ×                                | ×                                |
|                               | 0                                | 1                                | 1                                | 1                                 | 1                                | 1                                |
| PWM with dead time            | 0                                | 0                                | ×                                | 1                                 | ×                                | ×                                |
|                               | 0                                | 1                                | 1                                | 1                                 | ×                                | ×                                |
| 120° excitation               | 0                                | 0                                | ×                                | 1                                 | ×                                | ×                                |
|                               | 0                                | 1                                | 1                                | 1                                 | ×                                | ×                                |
| Special 120° excitation       | 0                                | 0                                | ×                                | 1                                 | ×                                | ×                                |
|                               | 0                                | 1                                | 1                                | 1                                 | ×                                | ×                                |
| Special pattern output        | 0                                | 0                                | ×                                | 1                                 | ×                                | ×                                |
|                               | 0                                | 1                                | 1                                | 1                                 | ×                                | ×                                |

#### Table 17-23 Reload rewriting setting by mode

Note 1. Except for TS0nRTE = 0 and TSnRBE = 0

**2.**  $\times$  indicates 1 or 0.



## (b) Caution for TSnCCR0 register in high-accuracy T-PWM mode

The output waveform changes according to reload occurrence at peak/trough when rewriting the TSnCCR0 register in the reload mode (batch rewrite function) (when TSnCMS of the TSnOPT0 register is 0, TSnRTE is 1, TSnRBE is 1, TSnRDE is 0, TSnICE is 1, and TSnIOE is 1 in the TSnOPT1 register).



Rewriting in the period of <1> (rewriting during count-up operation)

The next reload timing causes cycle change and asymmetric triangular waveform output on the count-down side because of the peak point reload timing. The duty value must be set again due to cycle change.



Note d1: TSnDTC1 setting value





Note d1: TSnDTC1 setting value

Rewriting at period <2> (Rewriting during count-down operation)

Because the next reload timing is at the trough point, the cycle value changes from the next cycle and the output remains a triangular waveform. The duty value must be set again due to cycle change.



Note d1: TSnDTC1 setting value



#### 16-bit counter "i' 'k Reloadable timing TSnCCR1 'k Δ TSnCCR1 buffer TOSn1 TOSn2 INTTSnCC1 <2> <1> <1> <2: Reload execution Reload execution $\Delta$ : write access

(c) Cautions for TSnCCR1 to TSnCCR3 registers in high-accuracy T-PWM mode

Rewriting in the period <1> (rewriting during count-up operation)

An asymmetric triangular waveform is output because of reload at the peak interrupt timing.

Rewriting in the period <2> (rewriting during count-down operation)

A symmetric triangular waveform is output because of reload at the trough interrupt timing.

## (d) Caution on rewriting TSnOPT1

Writing to the TSnOPT1 or TSnOPT1L registers clears the internal interrupt thinning out counter. Then, the interrupt interval may be longer temporarily when the interrupt thinning out function is used.

To avoid this situation, rewriting must be executed by performing a setting such that reloading is done in synchronization with interrupt thinning out (TSnCMS of the TSnOPT0 register is 0, or TSnRDE of the TSnOPT1 register is 1).



## (e) Caution on rewriting TSnCMS bit in high-accuracy T-PWM mode

Rewriting the TSnCMS bit of the TSnOPT0 register is possible during operation (TSnCE = 1), but care must be exercised in the TSnCCR1 register writing order.

Writing to the TSnCCR1 register under TSnCMS = 0 enables setting of the reload request signal (internal signal).

Setting of the reload request signal causes reload at the next reload timing, and the reload request signal is then cleared. The reload request signal is cleared by TSnCMS = 1 as well.



- <1> Writing to the TSnCCR1 register while TSnCMS = 0 enables setting of the reload request signal (internal signal). The reload request signal is cleared by setting TSnCMS to 1 under the above status.
- <2> Reload is not executed because the reload request signal is cleared by TSnCMS = 1.
- <3> Writing to the TSnCCR1 register while TSnCMS = 1 does not set the reload request signal. If TSnCMS is set to 0 after that, reload is not executed at the next reload timing.
- <4> Writing to the TSnCCR1 register while TSnCMS = 0 sets the reload request signal. Reload is executed at the next reload timing to clear the reload request signal.
- <5> Once reload is executed, the reload request signal is cleared. Therefore, reload is not executed at the next reload timing until the TSnCCR1 register is written to.



## 17.4.3 Output list in each mode

## (1) Timer output by each mode

The following list shows the timer outputs (TOSn0 to TOSn7 pins) in each mode.

| Table 17-24 | Timer Outputs in Each Mode (1/2) |
|-------------|----------------------------------|
|-------------|----------------------------------|

| Operation mode                        | TOSn0                                                                     | TOSn1                                                         | TOSn2                                                      | TOSn3                                                         |
|---------------------------------------|---------------------------------------------------------------------------|---------------------------------------------------------------|------------------------------------------------------------|---------------------------------------------------------------|
| Interval timer mode                   | Toggle output by<br>TSnCCR0 compare<br>match                              | Toggle output by<br>TSnCCR1 compare<br>match                  | Toggle output by<br>TSnCCR2 compare<br>match               | Toggle output by<br>TSnCCR3 compare<br>match                  |
| External event count mode             | Toggle output by<br>TSnCCR0 compare<br>match                              | Toggle output by<br>TSnCCR1 compare<br>match                  | Toggle output by<br>TSnCCR2 compare<br>match               | Toggle output by<br>TSnCCR3 compare<br>match                  |
| External trigger<br>pulse output mode | Toggle output by<br>TSnCCR0 compare<br>match or external<br>trigger input | External trigger<br>pulse waveform<br>output                  | External trigger<br>pulse waveform<br>output               | External trigger<br>pulse waveform<br>output                  |
| One-shot pulse<br>mode                | Active at count start<br>Inactive by<br>TSnCCR0 match                     | Active by TSnCCR1<br>match<br>Inactive by<br>TSnCCR0 match    | Active by TSnCCR2<br>match<br>Inactive by<br>TSnCCR0 match | Active by TSnCCR3<br>match<br>Inactive by<br>TSnCCR0 match    |
| PWM mode                              | Toggle output by<br>TSnCCR0 compare<br>match                              | PWM output by<br>TSnCCR1 compare<br>match                     | PWM output by<br>TSnCCR2 compare<br>match                  | PWM output by<br>TSnCCR3 compare<br>match                     |
| Free-running mode                     | Toggle output by<br>TSnCCR0 compare<br>match                              | Toggle output by<br>TSnCCR1 compare<br>match                  | Toggle output by<br>TSnCCR2 compare<br>match               | Toggle output by<br>TSnCCR3 compare<br>match                  |
| Triangular-wave<br>PWM mode           | Up/down status<br>output of 16-bit<br>counter                             | PWM output by<br>TSnCCR1 compare<br>match                     | PWM output by<br>TSnCCR2 compare<br>match                  | PWM output by<br>TSnCCR3 compare<br>match                     |
| High-accuracy T-<br>PWM mode          | Up/down status<br>output of 16-bit<br>counter or 16-bit<br>sub-counter    | PWM output by<br>TSnCCR1 compare<br>match (with dead<br>time) | Negative phase<br>output against<br>TOSn1                  | PWM output by<br>TSnCCR2 compare<br>match (with dead<br>time) |
| PWM mode with dead time               | Toggle output by<br>TSnCCR0 compare<br>match                              | PWM output by<br>TSnCCR1 compare<br>match (with dead<br>time) | Negative phase<br>output against<br>TOSn1                  | PWM output by<br>TSnCCR2 compare<br>match (with dead<br>time) |
| 120° excitation<br>mode               | Toggle output by<br>TSnCCR0 compare<br>match                              | PWM output using<br>TSnCCR1,<br>TSnCCR2                       | PWM output using<br>TSnCCR3,<br>TSnCCR4                    | PWM output using<br>TSnCCR1,<br>TSnCCR2                       |
| Special 120°<br>excitation mode       | Toggle output by<br>TSnCCR0 compare<br>match                              | Pattern output by TSnPAT0                                     | Pattern output by TSnPAT1                                  | Pattern output by<br>TSnPAT0                                  |
| Special pattern<br>output mode        | Pattern output by TSnPAT0[3:0]                                            | Pattern output by TSnPAT0[7:4]                                | Pattern output by TSnPAT0[11:8]                            | Pattern output by TSnPAT0[15:12]                              |

## Table 17-25 Timer Outputs in Each Mode (2/2)

| Operation mode      | TOSn4                                        | TOSn5                                        | TOSn6 | TOSn7 |
|---------------------|----------------------------------------------|----------------------------------------------|-------|-------|
| Interval timer mode | Toggle output by<br>TSnCCR4 compare<br>match | Toggle output by<br>TSnCCR5 compare<br>match | -     | -     |



| Operation mode                        | TOSn4                                                      | TOSn5                                                         | TOSn6                                     | TOSn7                                                          |
|---------------------------------------|------------------------------------------------------------|---------------------------------------------------------------|-------------------------------------------|----------------------------------------------------------------|
| External event count mode             | Toggle output by<br>TSnCCR4 compare<br>match               | Toggle output by<br>TSnCCR5 compare<br>match                  | -                                         | -                                                              |
| External trigger<br>pulse output mode | External trigger<br>pulse waveform<br>output               | External trigger<br>pulse waveform<br>output                  | -                                         | -                                                              |
| One-shot pulse<br>mode                | Active by TSnCCR4<br>match<br>Inactive by<br>TSnCCR0 match | Active by TSnCCR5<br>match<br>Inactive by<br>TSnCCR0 match    | -                                         | -                                                              |
| PWM mode                              | PWM output by<br>TSnCCR4 compare<br>match                  | PWM output by<br>TSnCCR5 compare<br>match                     | -                                         | Pulse output by A/D<br>conversion<br>trigger <sup>Note 1</sup> |
| Free-running mode                     | Toggle output by<br>TSnCCR4 compare<br>match               | Toggle output by<br>TSnCCR5 compare<br>match                  | -                                         | -                                                              |
| Triangular-wave<br>PWM mode           | PWM output by<br>TSnCCR4 compare<br>match                  | PWM output by<br>TSnCCR5 compare<br>match                     | -                                         | Pulse output by A/D<br>conversion<br>trigger <sup>Note 1</sup> |
| High-accuracy T-<br>PWM mode          | Negative phase<br>output against<br>TOSn3                  | PWM output by<br>TSnCCR3 compare<br>match (with dead<br>time) | Negative phase<br>output against<br>TOSn5 | Pulse output by A/D<br>conversion<br>trigger <sup>Note 1</sup> |
| PWM mode with dead time               | Negative phase<br>output against<br>TOSn3                  | PWM output by<br>TSnCCR3 compare<br>match (with dead<br>time) | Negative phase<br>output against<br>TOSn5 | Pulse output by A/D<br>conversion<br>trigger <sup>Note 1</sup> |
| 120° excitation<br>mode               | PWM output using<br>TSnCCR3,<br>TSnCCR4                    | PWM output using<br>TSnCCR1,<br>TSnCCR2                       | PWM output using<br>TSnCCR3,<br>TSnCCR4   | Pulse output by A/D<br>conversion<br>trigger <sup>Note 1</sup> |
| Special 120°<br>excitation mode       | Pattern output by TSnPAT1                                  | Pattern output by TSnPAT0                                     | Pattern output by TSnPAT1                 | Pulse output by A/D<br>conversion<br>trigger <sup>Note 1</sup> |
| Special pattern<br>output mode        | Pattern output by<br>TSnPAT1[3:0]                          | Pattern output by TSnPAT1[7:4]                                | Pattern output by TSnPAT1[11:8]           | Pattern output by TSnPAT1[15:12]                               |

Note 1. Refer to "TOSn7 pin output control" on page 707.

2. - indicates inactive level output.



## (a) TOSn7 pin output control

The A/D conversion trigger signal can be output to the TOSn7 pin. The TOSn7 pin becomes active at the rising edge of the TSnADTRG0 signal, and inactive at the rising edge of the TSnADTRG1 signal. If the TSnADTRG0 signal is detected during the active status of the TOSn7 pin, the TOSn7 pin remains active level. If the TSnADTRG1 signal is detected during the inactive status of the TOSn7 pin, the TOSn7 pin, the TOSn7 pin remains inactive level. The inactive status of the TOSn7 pin has priority if the TSnADTRG0 and TSnADTRG1 signal triggers are simultaneously generated.



Figure 17-8 TOSn7 pin output timing

Note Case 1: When TSnCCR4 < TSnCCR5, TSnOPT2 = 04H, TSnOPT3 = 10H Case 2: When TSnCCR4 < TSnCCR5, TSnOPT2 = 04H, TSnOPT3 = 20H Case 3: When TSnCCR4 < TSnCCR5, TSnOPT2 = 08H, TSnOPT3 = 10H



## (2) Interrupt in each mode

The following list shows the interrupts (INTTSnCC0 to INTTSnCC5, INTTSnOV, INTTSnER, INTTSnWN) in each mode.

| Table 17-26 | Interrupts | in Each | Mode ( | (1/3) |
|-------------|------------|---------|--------|-------|
|             |            |         |        |       |

| Operation mode                     | INTTSnCC0                          | INTTSnCC1                                            | INTTSnCC2                                         | INTTSnCC3                                            |
|------------------------------------|------------------------------------|------------------------------------------------------|---------------------------------------------------|------------------------------------------------------|
| Interval timer mode                | TSnCCR0 compare<br>match interrupt | TSnCCR1 compare<br>match interrupt <sup>Note 2</sup> | TSnCCR2 compare match interrupt <sup>Note 2</sup> | TSnCCR3 compare<br>match interrupt <sup>Note 2</sup> |
| External event count mode          | TSnCCR0 compare                    | TSnCCR1 compare                                      | TSnCCR2 compare                                   | TSnCCR3 compare                                      |
|                                    | match interrupt                    | match interrupt <sup>Note 2</sup>                    | match interrupt <sup>Note 2</sup>                 | match interrupt <sup>Note 2</sup>                    |
| External trigger pulse output mode | TSnCCR0 compare                    | TSnCCR1 compare                                      | TSnCCR2 compare                                   | TSnCCR3 compare                                      |
|                                    | match interrupt                    | match interrupt <sup>Note 2</sup>                    | match interrupt <sup>Note 2</sup>                 | match interrupt <sup>Note 2</sup>                    |
| One-shot pulse mode                | TSnCCR0 compare                    | TSnCCR1 compare                                      | TSnCCR2 compare                                   | TSnCCR3 compare                                      |
|                                    | match interrupt                    | match interrupt <sup>Note 2</sup>                    | match interrupt <sup>Note 2</sup>                 | match interrupt <sup>Note 2</sup>                    |
| PWM mode                           | TSnCCR0 compare                    | TSnCCR1 compare                                      | TSnCCR2 compare                                   | TSnCCR3 compare                                      |
|                                    | match interrupt                    | match interrupt <sup>Note 2</sup>                    | match interrupt <sup>Note 2</sup>                 | match interrupt <sup>Note 2</sup>                    |
| Free-running mode                  | TSnCCR0 compare                    | TSnCCR1 compare                                      | TSnCCR2 compare                                   | TSnCCR3 compare                                      |
|                                    | match interrupt                    | match interrupt                                      | match interrupt                                   | match interrupt                                      |
| Triangular-wave                    | TSnCCR0 compare                    | TSnCCR1 compare                                      | TSnCCR2 compare                                   | TSnCCR3 compare                                      |
| PWM mode                           | match interrupt                    | match interrupt <sup>Note 2</sup>                    | match interrupt <sup>Note 2</sup>                 | match interrupt <sup>Note 2</sup>                    |
| High-accuracy T-                   | TSnCCR0 compare                    | TSnCCR1 compare match interrupt <sup>Note 3</sup>    | TSnCCR2 compare                                   | TSnCCR3 compare                                      |
| PWM mode                           | match interrupt <sup>Note 1</sup>  |                                                      | match interrupt <sup>Note 3</sup>                 | match interrupt <sup>Note 3</sup>                    |
| PWM mode with                      | TSnCCR0 compare                    | TSnCCR1 compare                                      | TSnCCR2 compare                                   | TSnCCR3 compare                                      |
| dead time                          | match interrupt                    | match interrupt <sup>Note 2</sup>                    | match interrupt <sup>Note 2</sup>                 | match interrupt <sup>Note 2</sup>                    |
| 120° excitation mode               | TSnCCR0 compare                    | TSnCCR1 compare                                      | TSnCCR2 compare                                   | TSnCCR3 compare                                      |
|                                    | match interrupt                    | match interrupt <sup>Note 2</sup>                    | match interrupt <sup>Note 2</sup>                 | match interrupt <sup>Note 2</sup>                    |
| Special 120°                       | TSnCCR0 compare                    | TSnCCR1 compare                                      | TSnCCR2 compare                                   | TSnCCR3 compare                                      |
| excitation mode                    | match interrupt                    | match interrupt <sup>Note 2</sup>                    | match interrupt <sup>Note 2</sup>                 | match interrupt <sup>Note 2</sup>                    |
| Special pattern output mode        | TSnCCR0 compare                    | TSnCCR1 compare                                      | TSnCCR2 compare                                   | TSnCCR3 compare                                      |
|                                    | match interrupt                    | match interrupt <sup>Note 2</sup>                    | match interrupt <sup>Note 2</sup>                 | match interrupt <sup>Note 2</sup>                    |

**Note 1.** A compare match interrupt occurs only when 000H is set to the TSnDTC1 register. INTTSnCD0 can be used for peak interrupt.

- 2. Compare match interrupt does not occur when setting TSnCCR0 < TSnCCRm.
- 3. Compare match interrupt does not occur when setting is performed within the range of  $0000H \le TSnCCRm < TSnDTC0$ , (TSnCCR0 TSnDTC1) < TSnCCRm.
- **4**. m = 1 to 5



| Operation mode                        | INTTSnCC4                                            | INTTSnCC5                                            |
|---------------------------------------|------------------------------------------------------|------------------------------------------------------|
| Interval timer mode                   | TSnCCR4 compare match<br>interrupt <sup>Note 1</sup> | TSnCCR5 compare match<br>interrupt <sup>Note 1</sup> |
| External event count mode             | TSnCCR4 compare match<br>interrupt <sup>Note 1</sup> | TSnCCR5 compare match<br>interrupt <sup>Note 1</sup> |
| External trigger pulse<br>output mode | TSnCCR4 compare match<br>interrupt <sup>Note 1</sup> | TSnCCR5 compare match<br>interrupt <sup>Note 1</sup> |
| One-shot pulse mode                   | TSnCCR4 compare match<br>interrupt <sup>Note 1</sup> | TSnCCR5 compare match<br>interrupt <sup>Note 1</sup> |
| PWM mode                              | TSnCCR4 compare match<br>interrupt <sup>Note 1</sup> | TSnCCR5 compare match<br>interrupt <sup>Note 1</sup> |
| Free-running mode                     | TSnCCR4 compare match interrupt                      | TSnCCR5 compare match<br>interrupt                   |
| Triangular-wave PWM mode              | TSnCCR4 compare match<br>interrupt <sup>Note 1</sup> | TSnCCR5 compare match<br>interrupt <sup>Note 1</sup> |
| High-accuracy T-PWM mode              | TSnCCR4 compare match<br>interrupt <sup>Note 2</sup> | TSnCCR5 compare match<br>interrupt <sup>Note 2</sup> |
| PWM mode with dead time               | TSnCCR4 compare match<br>interrupt <sup>Note 1</sup> | TSnCCR5 compare match<br>interrupt <sup>Note 1</sup> |
| 120° excitation mode                  | TSnCCR4 compare match<br>interrupt <sup>Note 1</sup> | TSnCCR5 compare match<br>interrupt <sup>Note 1</sup> |
| Special 120° excitation mode          | TSnCCR4 compare match<br>interrupt <sup>Note 1</sup> | TSnCCR5 compare match<br>interrupt <sup>Note 1</sup> |
| Special pattern output mode           | TSnCCR4 compare match<br>interrupt <sup>Note 1</sup> | TSnCCR5 compare match<br>interrupt <sup>Note 1</sup> |

## Table 17-27 Interrupts in Each Mode (2/3)

- Note 1. Compare match interrupt does not occur when setting TSnCCR0 < TSnCCRm.
  - 2. Compare match interrupt is not generated when setting within the range of  $0000H \le TSnCCRm < TSnDTC0$ , (TSnCCR0 TSnDTC1) < TSnCCRm.
  - 3. m = 1 to 5



## Table 17-28 Interrupts in Each Mode (3/3)

| Operation mode                     | INTTSnOV                                | INTTSnER        | INTTSnWN                    |
|------------------------------------|-----------------------------------------|-----------------|-----------------------------|
| Interval timer mode                | -                                       | -               | -                           |
| External event count mode          | -                                       | -               | -                           |
| External trigger pulse output mode | -                                       | -               | -                           |
| One-shot pulse mode                | -                                       | -               | -                           |
| PWM mode                           | -                                       | Error interrupt | -                           |
| Free-running mode                  | Overflow interrupt                      | -               | -                           |
| Triangular-wave<br>PWM mode        | -                                       | Error interrupt | -                           |
| High-accuracy T-<br>PWM mode       | Overflow<br>interrupt <sup>Note 1</sup> | Error interrupt | Warning interrupt<br>Note 2 |
| PWM mode with dead time            | -                                       | Error interrupt | -                           |
| 120° excitation mode               | -                                       | Error interrupt | Warning interrupt           |
| Special 120°<br>excitation mode    | -                                       | Error interrupt | Warning interrupt           |
| Special pattern output mode        | -                                       | Error interrupt | -                           |

# Note 1. An overflow interrupt (INTTSnOV) occurs when setting TSnCCR0, TSnDTC0, and TSnDTC1 incorrectly.

2. Only when the  $180^\circ$  excitation control function is used



## (3) A/D conversion trigger, peak interrupt, trough interrupt in each mode

The A/D conversion triggers and peak/trough interrupts in each mode are listed below.

| Operation mode                     | TSnADTRG0                                                                                         | TSnADTRG1                                                                                         | INTTSnCD0                                                           | INTTSnOD         |
|------------------------------------|---------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|------------------|
| Interval timer mode                | -                                                                                                 | -                                                                                                 | -                                                                   | -                |
| External event count mode          | -                                                                                                 | -                                                                                                 | -                                                                   | -                |
| External trigger pulse output mode | -                                                                                                 | -                                                                                                 | -                                                                   | -                |
| One-shot pulse mode                | -                                                                                                 | -                                                                                                 | -                                                                   | -                |
| PWM mode                           | Select from<br>INTTSnCD0,<br>INTTSnCC4,<br>INTTSnCC5<br>interrupts <sup>Note 1</sup>              | Select from<br>INTTSnCD0,<br>INTTSnCC4,<br>INTTSnCC5<br>interrupts <sup>Note 1</sup>              | Peak interrupt at<br>the same timing<br>with INTTSnCC0<br>interrupt | -                |
| Free-running mode                  | -                                                                                                 | -                                                                                                 | -                                                                   | -                |
| Triangular-wave PWM mode           | Select from<br>INTTSnOD,<br>INTTSnCC4,<br>INTTSnCC5<br>interrupts <sup>Note 1</sup>               | Select from<br>INTTSnOD,<br>INTTSnCC4,<br>INTTSnCC5<br>interrupts <sup>Note 1</sup>               | -                                                                   | Trough interrupt |
| High-accuracy T-PWM mode           | Select from<br>INTTSnCD0,<br>INTTSnOD,<br>INTTSnCC4,<br>INTTSnCC5<br>interrupts <sup>Note 1</sup> | Select from<br>INTTSnCD0,<br>INTTSnOD,<br>INTTSnCC4,<br>INTTSnCC5<br>interrupts <sup>Note 1</sup> | Peak interrupt                                                      | Trough interrupt |
| PWM mode with dead time            | Select from<br>INTTSnCD0,<br>INTTSnCC4,<br>INTTSnCC5<br>interrupts <sup>Note 1</sup>              | Select from<br>INTTSnCD0,<br>INTTSnCC4,<br>INTTSnCC5<br>interrupts <sup>Note 1</sup>              | Peak interrupt at<br>the same timing<br>with INTTSnCC0<br>interrupt | -                |
| 120° excitation mode               | Select from<br>INTTSnCD0,<br>INTTSnCC4,<br>INTTSnCC5<br>interrupts <sup>Note 1</sup>              | Select from<br>INTTSnCD0,<br>INTTSnCC4,<br>INTTSnCC5<br>interrupts <sup>Note 1</sup>              | Peak interrupt at<br>the same timing<br>with INTTSnCC0<br>interrupt | -                |
| Special 120° excitation mode       | Select from<br>INTTSnCD0,<br>INTTSnCC4,<br>INTTSnCC5<br>interruptsNote 1                          | Select from<br>INTTSnCD0,<br>INTTSnCC4,<br>INTTSnCC5<br>interrupts <sup>Note 1</sup>              | Peak interrupt at<br>the same timing<br>with INTTSnCC0<br>interrupt | -                |
| Special pattern output mode        | Select from<br>INTTSnCD0,<br>INTTSnCC4,<br>INTTSnCC5<br>interrupts <sup>Note 1</sup>              | Select from<br>INTTSnCD0,<br>INTTSnCC4,<br>INTTSnCC5<br>interrupts <sup>Note 1</sup>              | Peak interrupt at<br>the same timing<br>with INTTSnCC0<br>interrupt | -                |

## Table 17-29 A/D Conversion Trigger, Peak Interrupt and Trough Interrupt



- Note 1. The TSnCCR4 and TSnCCR5 registers execute output control of the TOSn4 and TOSn5 pins (TOSn2, TOSn4, and TOSn6 pins in the 120° excitation mode) as well as determine the INTTSnCC4 and INTTSnCC5 timings. Therefore, the output timings of the TOSn4 and TOSn5 pins must be considered when using INTTSnCC4 and INTTSnCC5.
  - 2. INTTSnCD0 interrupt and INTTSnOD interrupt are the generation condition after interrupt thinning out.



## 17.5 Match Interrupt

Interrupt types include compare match interrupts (INTTSnCC0 to INTTSnCC5), peak interrupt (INTTSnCD0) and trough interrupt (INTTSnOD). Refer to *"Error/warning Interrupt" on page 752* for error/warning interrupts (INTTSNER, INTTSNWN).

Compare match interrupts (INTTSnCC0 to INTTSnCC5) occur regardless of the operation mode.

The peak interrupt (INTTSnCD0) occurs in the PWM mode, high-accuracy T-PWM mode, PWM mode with dead time, 120° excitation mode, special 120° excitation mode, and special pattern output mode. This interrupt is output at the switch timing from count-up operation to count-down operation of the 16-bit counter in the high-accuracy T-PWM mode. In the modes with 16-bit counter sawtooth wave operation (PWM mode, PWM mode with dead time, 120° excitation mode, special 120° excitation mode, and special pattern output mode), the peak interrupt occurs after match of the 16-bit counter and the TSnCCR0 register values (at the same timing as an INTTSnCC0 interrupt). The trough interrupt occurs at the switch timing from count-down operation to count-up operation of the 16-bit counter in the triangular-wave PWM output mode and high-accuracy T-PWM mode.



Figure 17-9 Interrupt signal output example (1/2) (high-accuracy T-PWM mode)

RENESAS



Figure 17-10 Interrupt signal output example (2/2) (example in PWM mode)



## 17.5.1 Caution on compare match interrupt

## (1) Caution on high-accuracy T-PWM mode

A compare match interrupt occurs upon a match between the 16-bit counter value and compare register (TSnCCR0 to TSnCCR5) values. Compare register setting beyond the 16-bit counter's count operation range is possible in the high-accuracy T-PWM mode. Therefore, compare match interrupts do not occur under the following conditions.

- Restriction concerning compare match interrupt of TSnCCR0 and the INTTSnCC0 register
   In the high-accuracy T-PWM mode, compare match interrupts (INTTSnCC0) does not occur while TSnDTC1 ≠ 0000H.
   Use INTTSnOD (trough interrupt)/INTTSnCD0 (peak interrupt) for the interrupt as a cycle.
   Restriction concerning the TSnCCR1 to TSnCCR3 registers
- Restriction concerning the TSnCCR1 to TSnCCR3 registers
   A compare match interrupt of match between the compare value and the 16bit counter value is not generated in the high-accuracy T-PWM mode if set within the following range.
   0000H ≤ TSnCCR1 to TSnCCR3 < TSnDTC0, TSnCCR0 to TSnDTC1 + 1 < TSnCCR1 to TSnCCR3 ≤ TSnCCR0</p>



Restriction concerning the TSnCCR4 and TSnCCR5 registers
 A compare match interrupt does not occur since a match between compare
 value and the 16-bit counter value is not generated in the high-accuracy T PWM mode if set within the following range.
 0000H ≤ TSnCCR4, TSnCCR5 < TSnDTC0,
 TSnCCR0 to TSnDTC1 + 1 < TSnCCR4, TSnCCR5 ≤ TSnCCR0</p>

The setting must be within the range of TSnDTC0  $\leq$  TSnCCR4, TSnCCR5  $\leq$  TSnCCR0 to TSnDTC1 because the TSnCCR4 and TSnCCR5 registers are used as a trigger source for A/D conversion triggers.





#### (2) Caution on PWM mode with dead time

A compare match interrupt occurs upon a match of the 16-bit counter and compare register (TSnCCR0 to TSnCCR5). Compare register setting beyond the count operation range of the 16-bit counter is possible in the T-PWM mode with dead time. Therefore, compare match interrupts do not occur under the following conditions.

Restrictions concerning the TSnCCR1 to TSnCCR5 registers
 A compare match interrupt does not occur if set within the following range in
 the PWM mode with dead time because no match occurs between the
 compare value and the 16-bit counter value.

TSnCCR0 < TSnCCR1 to TSnCCR5  $\leq$  TSnCCR0 + TSnDTC0 The setting must be within the range of TSnCCR4, TSnCCR5  $\leq$  TSnCCR0 when using the TSnCCR4 and TSnCCR5 registers because the TSnCCR4 and TSnCCR5 registers are used as trigger sources for A/D conversion triggers.



## 17.6 Flags

Table 17-30 Flag list

Note 1. Only in reload mode (when TSnCMS of the TSnOPT0 register is 0)



| No.  | Flag name                                                              | Symbol                   | Register | Operation mode                                                                                                                                                                                                                              |
|------|------------------------------------------------------------------------|--------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (1)  | Count-up flag                                                          | TSnCUF                   | TSnOPT0  | Triangular-wave PWM mode, high-accuracy T-PWM mode                                                                                                                                                                                          |
|      |                                                                        | TSnSUF                   | TSnOPT6  | High-accuracy T-PWM mode                                                                                                                                                                                                                    |
| (2)  | Positive/negative<br>simultaneous active<br>detection flag             | TSnTBF                   | TSnOPT6  | PWM mode, triangular-wave PWM mode, high-accuracy T-<br>PWM mode, PWM mode with dead time, 120° excitation<br>mode, special 120° excitation mode, and special pattern<br>output mode                                                        |
| (3)  | Reload request flag                                                    | TSnRSF                   | TSnOPT6  | External trigger pulse output mode, PWM mode, high-<br>accuracy T-PWM mode <sup>Note 1</sup> , triangular-wave PWM mode,<br>PWM mode with dead time, 120° excitation mode, special<br>120° excitation mode, and special pattern output mode |
| (4)  | Noise detection flag                                                   | TSnNDF                   | TSnOPT6  | High-accuracy T-PWM mode <sup>Note 2</sup> , PWM mode with dead time <sup>Note 2</sup> , 120° excitation mode, and special 120° excitation mode                                                                                             |
| (5)  | Pattern order<br>detection flag                                        | TSnTSF                   | TSnOPT5  | High-accuracy T-PWM mode <sup>Note 2</sup> , PWM mode with dead time <sup>Note 2</sup> , 120° excitation mode, and special 120° excitation mode                                                                                             |
| (6)  | Pattern error<br>detection flag                                        | TSnPEF                   | TSnOPT6  | High-accuracy T-PWM mode <sup>Note 2</sup> , PWM mode with dead time <sup>Note 2</sup> , 120° excitation mode, and special 120° excitation mode                                                                                             |
| (7)  | Pattern reverse detection flag                                         | TSnPRF                   | TSnOPT6  | High-accuracy T-PWM mode <sup>Note 2</sup> , PWM mode with dead time <sup>Note 2</sup> , 120° excitation mode, and special 120° excitation mode                                                                                             |
| (8)  | TAPTSn2 to<br>TAPTSn0 pins<br>abnormal toggle<br>detection flag        | TSnPTF                   | TSnOPT6  | High-accuracy T-PWM mode <sup>Note 2</sup> , PWM mode with dead time <sup>Note 2</sup> , 120° excitation mode, and special 120° excitation mode                                                                                             |
| (9)  | TSnSTCI0,<br>TSnSTCI1 signal<br>simultaneous trigger<br>detection flag | TSnTDF                   | TSnOPT6  | High-accuracy T-PWM mode <sup>Note 2</sup> , PWM mode with dead time <sup>Note 2</sup> , 120° excitation mode, and special 120° excitation mode                                                                                             |
| (10) | Pattern phase<br>difference detection<br>flag                          | TSnPPF                   | TSnOPT6  | High-accuracy T-PWM mode <sup>Note 2</sup> , PWM mode with dead time <sup>Note 2</sup> , 120° excitation mode, and special 120° excitation mode                                                                                             |
| (11) | Overflow flag                                                          | TSnOVF                   | TSnOPT0  | Free-running mode, and high-accuracy T-PWM mode <sup>Note 3</sup>                                                                                                                                                                           |
| (12) | Timer output pattern<br>flag                                           | TSnOPF0<br>to<br>TSnOPF2 | TSnOPT5  | High-accuracy T-PWM mode <sup>Note 4</sup> , PWM mode with dead time <sup>Note 4</sup> , 120° excitation mode, and special 120° excitation mode                                                                                             |
| (13) | Pattern switch<br>detection flag<br>(internal signal)                  | TSnESG                   | -        | High-accuracy T-PWM mode <sup>Note 2</sup> , PWM mode with dead time <sup>Note 2</sup> , 120° excitation mode, and special 120° excitation mode                                                                                             |

- Selectable only when the software output control function (TSnSOC of the TSnOPT4 register is 1) or 180° excitation function (TSnADC of the TSnOPT5 register is 1) is used.
- **3.** Selectable only when setting conditions for the TSnDTC0 and TSnDTC1 registers are incorrectly set.
- 4. Selectable only when the 180° excitation function (when TSnADC of the TSnOPT5 register is 1) is used.

# 17.6.1 Count-up flags (TSnCUF, TSnSUF)

[Name]



## Count-up flag (TSnCUF) - TSnOPT0 register (TSnSUF) - TSnOPT6 register

[Description]

There are two kinds of count-up flags as follows. TSnCUF is a count-up/down flag of 16-bit counter. TSnSUF is a count-up/down flag of 16-bit sub-counter. For both TSnCUF and TSnSUF, 0 indicates count-up operation and 1 indicates count-down operation.





Figure 17-11 Count-up flag operation example

The TSnCUF value is as follows.

[In triangular-wave PWM mode]

 $\label{eq:constraint} \begin{array}{l} 0 \leq 16\mbox{-bit counter} < TSnCCR0 + 1 \ ...... \ 0 \ (count-up) \\ TSnCCR0 + 1 \geq 16\mbox{-bit counter} > 0 \ ...... \ 1 \ (count-down) \end{array}$ 

[In high-accuracy T-PWM mode]

 $TSnDTC0 + 2 \le 16$ -bit counter < (TSnCCR0 - TSnDTC1) .... 0 (count-up) (TSnCCR0 - TSnDTC1 - 2)  $\ge 16$ -bit counter > TSnDTC0 .... 1 (count-down)

The TSnSUF value is as follows.

[In high-accuracy T-PWM mode]

 $0 \le 16$ -bit sub-counter < TSnCCR0 ...... 0 (count-up) TSnCCR0  $\ge 16$ -bit sub-counter > 0 ...... 1 (count-down)





Figure 17-12 TOSn0 Output at switch of TSnTOS bit of TSnOPT7 register

[Operation mode]

TSnCUF Triangular-wave PWM mode, high-accuracy T-PWM mode TSnSUF High-accuracy T-PWM mode



# 17.6.2 Positive/negative-phase simultaneous active detection flag (TSnTBF)

#### [Name]

Positive/negative phase simultaneous active detection flag (TSnTBF) - TSnOPT6 register

#### [Description]

Positive/negative phase simultaneous active of timer Sn can be detected by TSnTBF.





Figure 17-13 Positive/negative phase simultaneous active detection flag operation example

[Operation mode]

PWM mode, triangular-wave PWM mode, high-accuracy T-PWM mode, PWM mode with dead time, 120° excitation mode, special 120° excitation mode, special pattern output mode



### 17.6.3 Reload request flag (TSnRSF)

[Name]

Reload request flag (TSnRSF) - TSnOPT6 register

[Description]

TSnRSF is set to 1 when a reload request is generated (when the TSnCCR1 register is written). The reload request flag is cleared to 0 when reload is generated and the value is transferred to all the buffer registers.









Figure 17-15 Reload request flag and reload thinning out period



#### [Operation mode]

External trigger pulse output mode, PWM mode, high-accuracy T-PWM mode<sup>Note</sup>, triangular-wave PWM mode, PWM mode with dead time, 120° excitation mode, special 120° excitation mode, special pattern output mode

Note Only in reload mode (only when TSnCMS of the TSnOPT0 register is 0)

#### 17.6.4 Noise detection flag (TSnNDF)

[Name]

Noise detection flag (TSnNDF) - TSnOPT6 register

[Description]

TSnNDF can detect noise generation on the TAPTSn2 to TAPTSn0 pins. "Noise" means simultaneous change on two or more pins among the TAPTSn2 to TAPTSn0 pins.

The noise detection flag (TSnNDF) is set to 1 when simultaneous change is detected on two or more pins among TAPTSn2 to TAPTSn0 pins. Clear to 0 is executed when 0 is written to the TSnNDF flag, or TSnCE of the TSnCTL0 register is set to 0.

[Example]



#### Figure 17-16 Noise detection flag operation example

#### [Operation mode]

High-accuracy T-PWM mode<sup>Note</sup> and PWM mode with dead time<sup>Note</sup>

**Note** Selectable only when the software output control function (when TSnSOC of the TSnOPT4 register is 1) or 180° excitation function (when TSnADC of the TSnOPT5 register is 1) is used.



#### 17.6.5 Pattern order detection flag (TSnTSF)

[Name]

TSnTSF detects the order of the pattern input to the TAPTSn2 to TAPTSn0 pins.

Pattern order detection flag (TSnTSF) - TSnOPT5 register

#### [Description]

- The inputs the TAPTSn2 to TAPTSn0 pins result in the following operation.
- 0 is set when input to the TAPTSn2 to TAPTSn0 pins changes as follows. TAPTSn2 to TAPTSn0 =
  - $[1,\,0,\,1] \rightarrow [1,\,0,\,0] \rightarrow [1,\,1,\,0] \rightarrow [0,\,1,\,0] \rightarrow [0,\,1,\,1] \rightarrow [0,\,0,\,1]$
- 1 is set when input to TAPTSn2 to TAPTSn0 pins changes as follows. TAPTSn2 to TAPTSn0 =

 $[1, 0, 1] \leftarrow [1, 0, 0] \leftarrow [1, 1, 0] \leftarrow [0, 1, 0] \leftarrow [0, 1, 1] \leftarrow [0, 0, 1]$ 

#### [Example]

 When normal input is provided to the TAPTSn2 to TAPTSn0 pins As shown in *Figure 17-17 on page 723*, when the TAPTSn2 to TAPTSn0 pins are change in sequence, 0 or 1 is set according to the change order at the change timing.



Figure 17-17 Pattern order detection flag operation example (in normal case)



#### • In exceptions occurrence







## Figure 17-19 When inputs to pins TAPTSn2 to TAPTSn0 are changed to [0, 0, 0] or [1, 1, 1].

#### [Operation mode]

High-accuracy T-PWM mode<sup>Note</sup>, PWM mode with dead time<sup>Note</sup>, 120° excitation mode, and special 120° excitation mode

**Note** Selectable only when the software output control function (TSnSOC of the TSnOPT4 register = 1) or 180° excitation function (TSnADC of the TSnOPT5 register is 1) is used.



#### 17.6.6 Pattern error detection flag (TSnPEF)

#### [Name]

Pattern error detection flag (TSnPEF) - TSnOPT6 register

#### [Description]

TSnPEF can detect [0, 0, 0] or [1, 1, 1] input to the TAPTSn2 to TAPTSn0 pins.

TSnPEF is set to 1 when the pin level of the TAPTSn2 to TAPTSn0 pins is [0, 0, 0] or [1, 1, 1] level, and cleared when 0 is written to the TSnPEF flag, or while timer Sn operation is stopped (TSnCE of the TSnCTL0 register is set to 0).

#### [Example]



Figure 17-20 Pattern error detection flag operation example (TAPTSn2 to TAPTSn0 = [1, 1, 1])

[Operation mode]

High-accuracy T-PWM mode  $^{Note},$  PWM mode with dead time  $^{Note},$  120° excitation mode and special 120° excitation mode

**Note** Selectable only when the software output control function (TSnSOC of the TSnOPT4 register is 1) or 180° excitation function (TSnADC of the TSnOPT5 register is 1) is used.



#### 17.6.7 Pattern reverse detection flag (TSnPRF)

[Name]

Pattern reverse detection flag (TSnPRF) - TSnOPT6 register

[Description]

TSnPRF can detect reversal of change order of the TAPTSn2 to TAPTSn0 pins.

TSnPRF switches at the change timing of pattern order detection flag (TSnTSF). The TSnPRF flag is valid with the 2nd or later change of the TAPTSn2 to TAPTSn0 pins immediately after TSnCE of the TSnCTL0 register is set to 1.







Figure 17-22 Operation example immediately after TSnCE of TSnCTL0 register is set to 1



#### [Operation mode]

High-accuracy T-PWM mode  $^{Note},$  PWM mode with dead time  $^{Note},$  120° excitation mode, and special 120° excitation mode

**Note** Selectable only when the software output control function (TSnSOC of the TSnOPT4 register is 1) or 180° excitation function (TSnADC of the TSnOPT5 register is 1) is used.



# 17.6.8 TAPTSn2 to TAPTSn0 pin abnormal toggle detection flag (TSnPTF)

#### [Name]

TAPTSn2 to TAPTSn0 pins abnormal toggle detection flag (TSnPTF) - TSnOPT6 register

#### [Description]

TSnPTF can detect that three or more changes of the TAPTSn2 to TAPTSn0 pins are input between the TSnSTCI0 signal triggers, or between the TSnSTCI1 signal triggers. If the third trigger of the TSnSTCI0 and TSnSTCI1 signals and change of the TAPTSn2 to TAPTSn0 pins are generated simultaneously, the TSnPTF flag is set to 1 and a warning interrupt (INTTSnWN) occurs.



Figure 17-23 TAPTSn2 to TAPTSn0 pins abnormal toggle detection flag operation example

#### [Operation mode]

High-accuracy T-PWM mode<sup>Note</sup>, PWM mode with dead time<sup>Note</sup>, 120° excitation mode and special 120° excitation mode

**Note** Selectable only when the software output control function (TSnSOC of the TSnOPT4 register is 1) or 180° excitation function (TSnADC of the TSnOPT5 register is 1) is used.



- **Caution** 1. The TSnPTF flag is valid only when TSnPOT of the TSnOPT5 register = 1, TSnSOC of the TSnOPT4 register = 0, and TSnPTC1 of the TSnOPT7 register = 1.
  - 2. When TSnPOT = 1, TSnPTC0 = 1 and TSnPTC1 = 1, abnormal toggle detection leads automatic switch to the pattern switch system (TSnPOT = 0) by output switch control of TOSn1 to TOSn6 pins.
  - **Note** If the third trigger of the TSnSTCI0 and TSnSTCI1 signals and change of the TAPTSn2 to TAPTSn0 pins are generated simultaneously, a warning interrupt (INTTSnWN) occurs and the TSnPTF flag is set.



# 17.6.9 TSnSTCI0, TSnSTCI1 signal simultaneous trigger detection flag (TSnTDF)

#### [Name]

TSnSTCI0, TSnSTCI1 signal simultaneous trigger detection flag (TSnTDF) - TSnOPT6 register

#### [Description]

TSnTDF detects that the TSnSTCI0 and TSnSTCI1 signals become triggers simultaneously.

[Example]



Figure 17-24 TSnSTCI0, TSnSTCI1 signal simultaneous trigger detection flag operation example

[Operation mode]

High-accuracy T-PWM mode  $^{Note},$  PWM mode with dead time  $^{Note},$  120° excitation mode and special 120° excitation mode

- **Note** Selectable only when the software output control function (TSnSOC of the TSnOPT4 register = 1) or 180° excitation function (TSnADC of the TSnOPT5 register = 1) is used
- Caution The TSnTDF flag is valid only when TSnPOT of the TSnOPT5 register is 1, TSnSOC of the TSnOPT4 register is 0, and TSnPTC1 of the TSnOPT7 register is 1.



#### 17.6.10 Pattern phase difference detection flag (TSnPPF)

#### [Name]

Pattern phase difference detection flag (TSnPPF) - TSnOPT6 register

#### [Description]

TSnPPF can detect the phase difference between input pattern (TAPTSn2 to TAPTSn0 pins) and output pattern (TSnOPF2 to TSnOPF0 bits of TSnOPT5 register) when the semi-automatic driving system is used. The pattern phase difference is detected when the TSnSTCI0 or TSnSTCI1 signal is input, and the TSnPPF bit is then set. The TSnPPF bit remains 1 until it is cleared by software. When a phase difference is detected, the TSnPPF bit is set for each base clock ( $f_{TMSn}$ ) of timer Sn. Clear the TSnPPF bit (0) at a timing at which no phase differences may occur.

#### Table 17-31 Normal input/output pattern

[Example]

| TAPTSn2 to<br>TAPTSn0<br>(Input) | "1, 0, 1" | "1, 0, 0" | "1, 1, 0" | "0, 1, 0" | "0, 1, 1" | "0, 0, 1" |
|----------------------------------|-----------|-----------|-----------|-----------|-----------|-----------|
| TSnOPF2 to                       | "0, 0, 1" | "1, 0, 1" | "1, 0, 0" | "1, 1, 0" | "0, 1, 0" | "0, 1, 1" |
| TSnOPF0                          | "1, 0, 1" | "1, 0, 0" | "1, 1, 0" | "0, 1, 0" | "0, 1, 1" | "0, 0, 1" |
| (Output)                         | "1, 0, 0" | "1, 1, 0" | "0, 1, 0" | "0, 1, 1" | "0, 0, 1" | "1, 0, 1" |



Figure 17-25 Pattern phase difference detection flag operation example

#### [Operation mode]

High-accuracy T-PWM mode<sup>Note</sup>, PWM mode with dead time<sup>Note</sup>, 120° excitation mode and special 120° excitation mode

- Note Selectable only when the software output control function (TSnSOC of TSnOPT4 register is 1) or 180° excitation function (TSnADC of TSnOPT5 register is 1) is used
- Caution The TSnPPF flag is valid only when TSnPOT of the TSnOPT5 register is 1, TSnSOC of the TSnOPT4 register is 0, and TSnPPC of the TSnOPT7 register is 1.

RENESAS

### 17.6.11 Overflow flag (TSnOVF)

[Name]

Overflow flag (TSnOVF) - TSnOPT0 register

[Description]

TSnOVF is set to 1 when the 16-bit counter value overflows from FFFFH to 0000H.

This flag is cleared to 0 by writing 0 to it or the operation is stopped (TSnCE of the TSnCTL0 register = 0). If TSnOVF is set, an overflow interrupt (INTTSnOV) is generated simultaneously.

#### [Example]

Figure 17-26 Overflow flag operation example



[Operation mode]

Free-running mode and high-accuracy T-PWM mode<sup>Note</sup>

Note Only when the TSnDTC0, TSnDTC1 register values are incorrectly set



### 17.6.12 Timer output pattern flags (TSnOPF2 to TSnOPF0)

#### [Name]

Timer output pattern flags (TSnOPF2 to TSnOPF0) - TSnOPT5 register

#### [Description]

TSnOPF2 to TSnOPF0 are flags that indicate timer output patterns. Refer to *"Timer output pattern in each mode and function" on page 671* for details.

#### [Operation mode]

High-accuracy T-PWM mode  $^{Note},$  PWM mode with dead time  $^{Note},$  120° excitation mode and special 120° excitation mode

**Note** Selectable only when the 180° excitation function (TSnADC of TSnOPT5 register = 1) is used



#### 17.6.13 Pattern switch detection flag (TSnESG)

#### [Name]

Pattern switch detection flag (TSnESG) - Internal signal

[Description]

TSnESG is toggled at the change timing of input pattern (TAPTSn2 to TAPTSn0).

| TAPTSn2 to TAPTSn0 After Change |           |           |           |           |           |           |           |           |           |  |
|---------------------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|--|
|                                 |           | [0, 0, 0] | [1, 1, 1] | [1, 0, 1] | [1, 0, 0] | [1, 1, 0] | [0, 1, 0] | [0, 1, 1] | [0, 0, 1] |  |
| TAPTSn2 to TAPTSn0              | [0, 0, 0] | -         | -         | -         | -         | -         | -         | -         | -         |  |
| at present                      | [1, 1, 1] | -         | -         | -         | -         | -         | -         | -         | -         |  |
|                                 | [1, 0, 1] | -         | -         | -         | Toggle    | -         | -         | -         | Toggle    |  |
|                                 | [1, 0, 0] | -         | -         | Toggle    | -         | Toggle    | -         | -         | -         |  |
|                                 | [1, 1, 0] | -         | -         | -         | Toggle    | -         | Toggle    | -         | -         |  |
|                                 | [0, 1, 0] | -         | -         | -         | -         | Toggle    | -         | Toggle    | -         |  |
|                                 | [0, 1, 1] | -         | -         | -         | -         | -         | Toggle    | -         | Toggle    |  |
|                                 | [0, 0, 1] | -         | -         | Toggle    | -         | -         |           | Toggle    | -         |  |

#### [Example]

|         |  |  |  |  | <br> |  |
|---------|--|--|--|--|------|--|
| TAPTSn2 |  |  |  |  |      |  |
| TAPTSn1 |  |  |  |  |      |  |
| TAPTSn0 |  |  |  |  |      |  |
| TSnESG  |  |  |  |  |      |  |

Figure 17-27 Pattern switch detection flag operation example

[Operation mode]

High-accuracy T-PWM mode  $^{Note},$  PWM mode with dead time  $^{Note},$  120° excitation mode and special 120° excitation mode

**Note** Selectable only when the 180° excitation function (TSnADC of TSnOPT5 register = 1) is used



### 17.7 Interrupt Thinning out Function

The operations related to the interrupt thinning out function are as follows.

- The interrupts to be culled are peak interrupt (INTTSnCD0) and trough interrupt (INTTSnOD).
- The TSnICE bit of the TSnOPT1 register is used to enable the output of INTTSnCD0 interrupts and specify the interrupt thinning out count.
- The TSnIOE bit of the TSnOPT1 register is used to enable the output of INTTSnOD interrupts and specify the interrupt thinning out count.
- Whether or not reload thinning out is to be performed can be specified with the TSnRDE bit of the TSnOPT2 register.
   If the use of reload thinning out is specified, reloading is executed at the same time as an interrupt output after the thinning out.
   If the use of reload thinning out is not specified, reloading is executed at the reload timing after a write access is performed on the TSnCCR1 register.
- **Caution 1.** The interrupt thinning out function is enabled in the PWM mode, triangularwave PWM mode, high-accuracy T-PWM mode, PWM mode with dead time, 120° excitation mode, special 120° excitation mode, or special pattern output mode.
  - 2. If a write access is performed on the TSnOPT1 or TSnOPT1L register by using the anytime rewrite mode or reload mode (batch rewrite function), the internal thinning out counter is cleared. Therefore, the interrupt interval may be extended temporarily when the interrupt thinning out function is used. To avoid this, change the interrupt thinning out count so that the values are reloaded to the counter in synchronization with the interrupt thinning out (TSnCMS of the TSnOPT0 register = 0, or TSnRDE of the TSnOPT1 register = 1).



rec

### 17.7.1 Interrupt thinning out function operation

4. Interrupt thinning out operation when TSnICE and TSnIOE of the TSnOPT1 register are 1 (when a peak/trough interrupt occurs in high-accuracy T-PWM mode)



 Interrupt thinning out operation when the TSnICE and TSnIOE of the TSnOPT1 register are 1 (when only a peak interrupt occurs in highaccuracy T-PWM mode)



6. Interrupt thinning out operation when the TSnOPT1 register's TSnICE is 0



#### Chapter 17

#### 16-bit counter TSnID4 to TSnID0 = 00H (No thinning out) INTTSnCD0 INTTSnOD 'n л n n TSnID4 to TSnID0 = 01H (1 mask) INTTSnCD0 (<sup>\*\*</sup>) $\langle \hat{} \rangle$ INTTSnOD ð, 'n 'n TSnID4 to TSnID0 = 02H (2 masks) INTTSnCD0 INTTSnOD TSnID4 to TSnID0 = 03H $\langle \hat{} \rangle$ 67) ് ď 'n (3 masks) INTTSnCD0 INTTSnOD 477 477 47 Å TSnID4 to TSnID0 = 04H (4 masks) INTTSnCD0 INTTSnOD Ċ ď ( )ď h -1

and TSnIOE is 1 (when only a trough interrupt occurs in high-accuracy T-PWM mode)



# 17.7.2 Operation example when peak and trough interrupts occur alternatively (in high-accuracy T-PWM mode)

#### (1) Register setting

TSnICE = 1, TSnIOE = 1, TSnRBE = 1, and TSnRTE = 0 for the TSnOPT1 register



#### (2) Operation example

**Note** Values are reloaded at the thinning out interrupt output timing, and other reload timings are ignored.



Figure 17-29 When TSnCMS of TSnOPT0 Register = 0 and TSnRDE of TSnOPT1 Register = 0 (Reload Function Selected)

Note Values are reloaded at the reload timing after rewriting.



Figure 17-28 When TSnCMS of TSnOPT0 Register = 0 and TSnRDE of TSnOPT1 Register = 1 (Reload Thinning out Function Selected) (Recommended Setting)





Figure 17-30 When TSnCMS of TSnOPT0 register = 1 and TSnRDE of TSnOPT1 register is x (in anytime rewrite mode)

- Note The reload timing is ignored after rewriting, and the value is immediately reflected. The counter is cleared when the value is transferred to the buffer, not when the register is rewritten.
- Caution The interrupt interval may be extended.



#### 17.7.3 Operation example when only peak interrupt occurs (in highaccuracy T-PWM mode)

(1) Register setting

TSnICE = 1, TSnIOE = 0, TSnRBE = 0, and TSnRTE = 1 for the TSnOPT1 register



### (2) Operation example

# Figure 17-31 When TSnCMS of TSnOPT0 register = 0 and TSnRDE of TSnOPT1 register = 1 (reload function selected) (recommended setting)

**Note** Values are reloaded at the thinning out interrupt output timing, and other reload timings are ignored.



## Figure 17-32 When TSnCMS of TSnOPT0 register = 0 and TSnRDE of TSnOPT1 register = 0 (reload function selected)

Note Values are reloaded at the reload timing after rewriting.





- Figure 17-33 When TSnCMS of TSnOPT0 register = 1 and TSnRDE of TSnOPT1 register = x (in anytime rewrite mode)
  - **Note 1.** The reload timing is ignored after rewriting, and then the value is immediately reflected.
    - 2. The counter is cleared when the value is transferred to the buffer, not when the register is rewritten.



# 17.7.4 Operation example when only trough interrupt occurs (in high-accuracy T-PWM mode)

#### (1) Register setting

TSnICE = 0, TSnIOE = 1, TSnRBE = 1, and TSnRTE = 0 in the TSnOPT1 register



#### (2) Operation example

Figure 17-34 When TSnCMS of TSnOPT0 register = 0 and TSnRDE of TSnOPT1 register = 1 (reload thinning out function) (recommended setting)

**Note** Values are reloaded at the thinning out interrupt output timing and other reload timings are ignored.



Figure 17-35 TSnOPT0 register TSnCMS = 0 and TSnOPT1 register TSnRDE = 0 (reload function)

Note Values are reloaded at the reload timing after rewriting.





- Figure 17-36 When TSnCMS of TSnOPT0 register = 1 and TSnRDE of TSnOPT1 register = x (in anytime rewrite mode)
  - **Note 1.** The reload timing is ignored and the value is immediately reflected after rewriting.
    - 2. The counter is cleared when the value is transferred to the buffer, not when the register is rewritten.



# 17.7.5 Operation example when only peak interrupt occurs (in PWM mode)

The operations related to the interrupt thinning out function in the PWM mode are as follows.

- The interrupt to be culled is the peak interrupt (INTTSnCD0). This interrupt is generated upon a match between the TSnCCR0 register and 16-bit counter during saw tooth wave operation.
- The TSnICE bit of the TSnOPT1 register is used to enable output of the INTTSnCD0 interrupt and specify the interrupt thinning out count.
- TSnIOE bit setting in the TSnOPT1 register is invalid. In this case, generation of INTTSnOD interrupts is disabled.
- Whether or not the reload thinning out is to be performed can be specified with the TSnRDE bit of the TSnOPT1 register.
   If the use of the reload thinning out is specified, reloading is executed at the same time as an interrupt output after the thinning out.
   If the use of the reload thinning out is not specified, reloading is executed at the peak timing after a write access is performed on the TSnCCR1 register.
- **Caution** If a write access is performed on the TSnOPT1 or TSnOPT1L register by using the anytime rewrite mode or reload mode (batch rewrite function), the internal thinning out counter is cleared. Therefore, the interrupt interval may be extended temporarily when the interrupt thinning out function is used. To avoid this, change the interrupt thinning out count so that the values are reloaded to the counter in synchronization with the interrupt thinning out (TSnCMS of the TSnOPT0 register = 0, or TSnRDE of the TSnOPT1 register = 1).



#### (1) Operation example

- Figure 17-37 When TSnCMS of TSnOPT0 register = 0 and TSnRDE of TSnOPT1 register = 1 (reload thinning out function) (recommended setting)
  - **Note** Values are reloaded at the thinning out interrupt output timing and other reload timings are ignored.





Figure 17-38 When TSnCMS of TSnOPT0 register = 0 and TSnRDE of TSnOPT1 register = 0 (reload function)

Note Values are reloaded at the reload timing after rewriting.

Caution The interrupt interval may be extended.



Figure 17-39 When TSnCMS of TSnOPT0 register = 1 and TSnRDE of TSnOPT1 register = x (in anytime rewrite mode)

Note The reload timing is ignored and the value is immediately reflected after rewriting. The counter is cleared when the value is transferred to the buffer, not when the register is rewritten.



### 17.8 A/D Conversion Trigger Function

The following describes the A/D conversion trigger output in PWM mode, triangular-wave PWM mode, high-accuracy T-PWM mode, PWM mode with dead time, 120° excitation mode, special 120° excitation mode and special pattern output mode.

In the high-accuracy T-PWM mode, PWM mode with dead time, special 120° excitation mode, or special pattern output mode, the TSnCCR4 and TSnCCR5 registers do not affect the timer output as compare operation but are used for controlling match interrupts and A/D conversion triggers.

In the PWM mode, triangular-wave PWM mode, or 120° excitation mode, note that the setting of the TSnCCR4 and TSnCCR5 registers may affect the timer output.

Refer to "A/D conversion trigger, peak interrupt, trough interrupt in each mode" on page 711 for details on A/D conversion triggers that can be output in each mode.



Figure 17-40 A/D conversion trigger output control circuit

The interrupt signals for compare match interrupts (INTTSnCC5, INTTSnCC4), peak interrupt (INTTSnCD0), trough interrupt (INTTSnOD), the 16-bit subcounter peak timing, and the 16-bit sub-counter trough timing can be selected to provide OR output as shown in *Figure 17-40 on page 746*.

Timer Sn has two channels of the same A/D trigger control circuits. Each can be controlled independently.

The A/D trigger thinning out functions are equipped to enable setting with 1/2, 1/4, or 1/8 thinning out ratio, or without thinning out.

RENESAS

#### 17.8.1 A/D conversion trigger operation

Timer Sn has a function that generates an A/D conversion start trigger (TSnADTRG0 or TSnADTRG1 signal) by arbitrarily selecting eight trigger sources.

The following eight trigger sources can be selected with the TSnAT07 to TSnAT00 bits of the TSnOPT2 register or the TSnAT17 to TSnAT10 bits of the TSnOPT3 register.

The following describes TSnADTRG0/TSnADTRG1 signal control using control bits TSnAT07 to TSnAT00/TSnAT17 to TSnAT10.

## (1) Output control of TSnADTRG0/TSnADTRG1 (TSnOPT2 and TSnOPT3 registers)

<Trigger source>

- TSnAT00/TSnADT10 = 1 An A/D conversion trigger is generated when a trough interrupt (INTTSnOD) occurs
- TSnAT01/TSnADT11 = 1 An A/D conversion trigger is generated when a peak interrupt (INTTSnOD0) occurs.
- TSnAT02/TSnADT12 = 1 An A/D conversion trigger generation is enabled when a compare match interrupt (INTTSnCC4) occurs during 16-bit counter count-up operation.
- TSnAT03/TSnADT13 = 1 An A/D conversion trigger is enabled when a compare match interrupt (INTTSnCC4) occurs during 16-bit counter count-down operation.
- TSnAT04/TSnADT14 = 1 An A/D conversion trigger generation is enabled when a compare match interrupt (INTTSnCC5) occurs 16-bit counter during count-up operation.
- TSnAT05/TSnADT15 = 1 An A/D conversion trigger generation is enabled when a compare match interrupt (INTTSnCC5) occurs during 16-bit counter count-down operation.
- TSnAT06/TSnADT16 = 1 An A/D conversion trigger generation is enabled at a peak of the 16-bit subcounter (when the timing is switched from up to down).
- TSnAT07/TSnADT17 = 1 A/D conversion trigger generation is enabled at a trough of the 16-bit subcounter (when the timing is switched from down to up).

<Thinning out setting>

 TSnACC01, TSnACC00 bits/TSnACC11, TSnACC10 bits TSnADTRG0/TSnADTRG1 signal thinning out setting

A/D conversion start trigger signals are undergo ORing, and then culled as specified with the TSnACC01, TSnACC00/TSnACC11, TSnACC10 bits, and are output to the TSnADTRG0 or TSnADTRG1 signal.

The peak interrupt (INTTSnOD) and trough interrupt (INTTSnOD) selected by the TSnAT00 and TSnAT01/TSnAT10, TSnAT11 bits are signals that are output after interrupt thinning out.

Therefore, output is provided at the timing when it is subject to interrupt thinning out control. If interrupt output (TSnICE and TSnIOE bits of TSnOPT1 register) is not enabled, neither can the A/D conversion start trigger be output.



The TSnACC01, TSnACC00, TSnAT07 to TSnAT00/TSnACC11, TSnACC10, TSnAT17 to TSnAT10 bits can be rewritten during timer operation. If a bit that sets an A/D conversion start trigger is rewritten during timer operation, the output status of the A/D conversion start trigger is reflected immediately.

These control bits can be written anytime regardless of the operation mode. When TSnACC01, TSnACC00/TSnACC11, TSnACC10 are written, the A/D conversion trigger thinning out counter is cleared and starts counting from 0. (The thinning out counter is also cleared when the same value is rewritten.)

| 16-bit counter                                                                                                                                                                   |                                                                    |                                                                                             |                        |                                                         |                                       | $\wedge$                                                                                    | $\sim$                                                   | $\wedge$                                               | $\sim$                           | $\wedge$                   | $\sim$                      | $\wedge$            | $\sim$        | $\wedge$ |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|---------------------------------------------------------------------------------------------|------------------------|---------------------------------------------------------|---------------------------------------|---------------------------------------------------------------------------------------------|----------------------------------------------------------|--------------------------------------------------------|----------------------------------|----------------------------|-----------------------------|---------------------|---------------|----------|
| INTTSnCD0                                                                                                                                                                        | <br>                                                               |                                                                                             | n                      | n                                                       | •  <br>     <br>                      | 0                                                                                           |                                                          | n                                                      |                                  | n                          |                             | n                   | 1 "<br>1<br>1 | n        |
| INTTSnOD                                                                                                                                                                         |                                                                    | n                                                                                           |                        |                                                         | _n                                    |                                                                                             | Π                                                        |                                                        | ſ                                |                            | n                           |                     | ſ             |          |
| INTTSnCC4                                                                                                                                                                        | <u>n</u>                                                           |                                                                                             |                        |                                                         |                                       |                                                                                             |                                                          |                                                        |                                  |                            |                             | <br> <br>           |               |          |
| INTTSnCC5                                                                                                                                                                        |                                                                    | n                                                                                           |                        |                                                         |                                       | JU                                                                                          |                                                          |                                                        |                                  | J                          |                             | J                   | ,<br>,<br>,   |          |
| TSnCUF                                                                                                                                                                           |                                                                    |                                                                                             | r÷                     |                                                         |                                       |                                                                                             |                                                          |                                                        |                                  |                            |                             |                     |               |          |
| Sub-counter<br>peak –                                                                                                                                                            | ń                                                                  |                                                                                             | _ <u>_</u>             |                                                         |                                       |                                                                                             |                                                          |                                                        |                                  |                            |                             |                     | Ĺ             |          |
| Sub-counter<br>trough                                                                                                                                                            |                                                                    | i_                                                                                          |                        | Ĺ                                                       | i                                     |                                                                                             |                                                          |                                                        |                                  |                            |                             |                     |               |          |
| [When TSnAT07                                                                                                                                                                    | to TSnAT00                                                         | ) = 00000                                                                                   | ,<br>0001B] IN         | ITTSn0                                                  | OD is c                               | output                                                                                      |                                                          |                                                        |                                  |                            |                             | <br> <br>           | <br> <br>     |          |
| TSnADTRG0                                                                                                                                                                        |                                                                    |                                                                                             |                        |                                                         | L.                                    |                                                                                             |                                                          |                                                        |                                  |                            |                             |                     |               |          |
| When TSnAT07                                                                                                                                                                     | to TSnAT00                                                         | = 00000                                                                                     | 010B] IN               | TTSnC                                                   | D0 is o                               | output                                                                                      | t l                                                      |                                                        |                                  |                            |                             | 1                   | 1             |          |
| TSnADTRG0                                                                                                                                                                        | ſ_                                                                 |                                                                                             | <u>π</u> ¦             |                                                         |                                       |                                                                                             |                                                          |                                                        |                                  |                            |                             |                     | <br> <br>     |          |
| [When TSnAT07                                                                                                                                                                    | to TSnAT00                                                         | ) = 00000                                                                                   | 0100B] IN              | ITTSn(                                                  | CC4 of                                | coun                                                                                        | t-up op                                                  | peratio                                                | n is ou                          | utput                      |                             | 1                   | 1             |          |
| TSnADTRG0                                                                                                                                                                        |                                                                    |                                                                                             |                        |                                                         |                                       |                                                                                             |                                                          |                                                        |                                  |                            |                             | 1<br>1<br>1         |               |          |
|                                                                                                                                                                                  | 1                                                                  |                                                                                             |                        |                                                         |                                       |                                                                                             |                                                          | i i                                                    |                                  | i                          |                             |                     |               | i i      |
| IVVhen [SnAT07                                                                                                                                                                   | to TSnAT00                                                         | $0 = 0000^{2}$                                                                              | 100 <sup>0</sup> B1 IN | ,<br>ITTSn(                                             | CC4 of                                | count                                                                                       | t-dowr                                                   | n opera                                                | ation is                         | s outpi                    | ut                          | 1                   |               |          |
| [When TSnAT07<br>TSnADTRG0                                                                                                                                                       | 1                                                                  | 1                                                                                           | 1 - T                  | I 1                                                     | i i                                   |                                                                                             |                                                          |                                                        | _                                |                            | ut<br>N                     | <br> <br> <br> <br> | п             |          |
| TSnADTRG0                                                                                                                                                                        |                                                                    |                                                                                             |                        |                                                         |                                       |                                                                                             | <u></u>                                                  |                                                        |                                  |                            | ut<br>                      |                     | <u> </u>      |          |
| TSnADTRG0<br>[When TSnAT07                                                                                                                                                       | to TSnAT00                                                         | 0 = 00010                                                                                   |                        | ITTSn                                                   | CC5 of                                |                                                                                             | <u></u>                                                  |                                                        |                                  |                            | ut<br>                      |                     | <u> </u>      |          |
| TSnADTRG0                                                                                                                                                                        |                                                                    | 0 = 00010                                                                                   |                        | ITTSn                                                   | CC5 of                                |                                                                                             | <u></u>                                                  |                                                        |                                  |                            | ut<br>_ <b>1</b>            |                     | <u> </u>      |          |
| TSnADTRG0<br>[When TSnAT07                                                                                                                                                       | to TSnAT00                                                         | 0 = 00010                                                                                   | <b>1</b><br>0000B] IN  | ITTSn(                                                  | CC5 of                                | count                                                                                       | <b>I</b><br>t-up or                                      | peratio                                                | n is o                           | utput                      | <u></u>                     |                     | <u> </u>      |          |
| TSnADTRG0<br>[When TSnAT07<br>TSnADTRG0                                                                                                                                          | to TSnAT00                                                         | 0 = 00010                                                                                   | <b>1</b><br>0000B] IN  | ITTSn(                                                  | CC5 of                                | count                                                                                       | <b>I</b><br>t-up or                                      | peratio                                                | n is o                           | utput                      | <u></u>                     |                     | <u> </u>      |          |
| TSnADTRG0                                                                                                                                                                        | to TSnAT00                                                         | ) = 00010<br>) = 00100                                                                      | 0000B] IN              | ITTSn(<br>ITTSn(                                        | <b>Л</b><br>CC5 of                    | f count                                                                                     | <b>n</b><br>t-up op<br>t-dowr                            | oeratio                                                | n is o                           | utput                      | <u></u>                     | (                   | <b>.</b>      |          |
| TSnADTRG0<br>[When TSnAT07<br>TSnADTRG0<br>[When TSnAT07                                                                                                                         | to TSnAT00                                                         | P = 00010<br>P = 00100<br>P = 01000                                                         | 0000B] IN              | ITTSn(<br>ITTSn(                                        | <b>Л</b><br>CC5 of                    | f count                                                                                     | <b>n</b><br>t-up op<br>t-dowr                            | oeratio                                                | n is o                           | utput                      | <u></u>                     | (                   |               |          |
| TSnADTRG0<br>[When TSnAT07<br>TSnADTRG0<br>[When TSnAT07<br>TSnADTRG0<br>[When TSnAT07                                                                                           | to TSnAT00<br>to TSnAT00<br>to TSnAT00                             | $\int_{0}^{1} = 00010$ $\int_{0}^{1} = 00100$ $\int_{0}^{1} = 01000$                        |                        | ITTSn(<br>ITTSn(<br>Ib-coui                             | CC5 of                                | count<br>count<br>bugh is                                                                   | f-up op<br>t-dowr<br>s outpu                             | oeratio                                                | n is o                           | utput                      | <u></u>                     | (                   |               |          |
| TSnADTRG0<br>[When TSnAT07<br>TSnADTRG0<br>[When TSnAT07<br>TSnADTRG0<br>[When TSnAT07<br>TSnADTRG0                                                                              | to TSnAT00<br>to TSnAT00<br>to TSnAT00                             | $\int_{0}^{1} = 00010$ $\int_{0}^{1} = 00100$ $\int_{0}^{1} = 01000$                        |                        | ITTSn(<br>ITTSn(<br>Ib-coui                             | CC5 of                                | count<br>count<br>bugh is                                                                   | f-up op<br>t-dowr<br>s outpu                             | oeratio                                                | n is o                           | utput                      | <u></u>                     |                     |               |          |
| TSnADTRG0                                                                                                                                                                        | to TSnAT00<br>to TSnAT00<br>to TSnAT00<br>to TSnAT00               | $ \mathbf{n} = 00010 $ $ \mathbf{n} = 00100 $ $ \mathbf{n} = 01000 $ $ \mathbf{n} = 00100 $ |                        | ITTSn(<br>ITTSn(<br>ib-coui<br>sub-co                   | CC5 of                                | count<br>f count<br>f count<br>bugh is<br>trough                                            | t-up of<br>t-dowr<br>s outpu                             | oeratio                                                | n is or                          | utput<br>1<br>s outpu<br>1 |                             |                     | <br>gh        |          |
| TSnADTRG0<br>[When TSnAT07<br>TSnADTRG0<br>[When TSnAT07<br>TSnADTRG0<br>[When TSnAT07<br>TSnADTRG0<br>[When TSnAT07                                                             | to TSnAT00<br>to TSnAT00<br>to TSnAT00<br>to TSnAT00               |                                                                                             |                        | ITTSn(<br>ITTSn(<br>Ib-course)<br>sub-course)<br>D conv | CC5 of                                | f count<br>count<br>ough is<br>trough                                                       | f-up op<br>t-dowr<br>s outpu<br>n is ou                  | oeratio                                                | on is on<br>ation is             | s output                   | ut<br>ak an                 | !                   | <br>gh        |          |
| TSnADTRG0<br>[When TSnAT07<br>TSnADTRG0<br>[When TSnAT07<br>TSnADTRG0<br>[When TSnAT07<br>TSnADTRG0<br>[When TSnAT07<br>TSnADTRG0<br>[When TSnAT07<br>TSnADTRG0<br>[When TSnAT07 | to TSnAT00<br>to TSnAT00<br>to TSnAT00<br>to TSnAT00<br>to TSnAT00 |                                                                                             |                        | ITTSn(<br>ITTSn(<br>ib-cour<br>sub-co<br>D con          | CC5 of<br>CC5 of<br>ounter<br>version | <sup>c</sup> count<br>count<br>count<br>bugh is<br>trough<br>start tr<br>atart tr<br>nd INT | f-up op<br>t-dowr<br>s outpu<br>n is ou<br>igger<br>TSnC | oeration<br>operation<br>ut<br>ut<br>is outp<br>C5 are | on is on<br>ation is<br>out at t | ooth po                    | ut<br>at<br>ak an<br>output | <b></b>             | gh            |          |

Figure 17-41 When TSnICE = 1, TSnIOE = 1, TSnID4 to TSnID0 = 00H for TSnOPT1 register and TSnACC01, TSnACC00 bits = 00H for TSnOPT2 register (in high-accuracy T-PWM mode)

RENESAS







Figure 17-43 When TSnICE = 0, TSnIOE = 1, TSnID4 to TSnID0 = 02H for TSnOPT1 register and TSnACC01, TSnACC00 Bits = 00H for TSnOPT2 register (in high-accuracy T-PWM mode)



#### (2) A/D conversion trigger thinning out function

An operation example of the A/D conversion trigger thinning out function is shown below.

| $\land \land \land \land \land \land \land \land$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16-bit counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [When TSnAT07 to TSnAT00 = 00100101B and TSnACC01 to TSnACC00 = 01B]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| $TSnADTRG0 \longrightarrow TSnADTRG0 \longrightarrow TS$ |
| [When TSnAT07 to TSnAT00 = 00100101B and TSnACC01 to TSnACC00 = 10B]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ISnADIRG0       Image: Comparison of the second secon                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

Figure 17-44 Operation example of A/D conversion trigger thinning out function (except TSnDTC = 000H)

**Caution** The AD trigger thinning out counter operation differs according to whether the dead time register (TSnDTC0) is "000H" or "other than 000H". When the TSnDTC0 register is "000H", the 16-bit sub-counter trough of the first cycle from timer count start is not counted so that there is a difference in the AD trigger thinning out counter start timing as shown in *Figure 17-44 on page 750*.





Figure 17-45 Operation example of A/D Conversion trigger thinning out function (TSnDTC = 000H)

#### (3) Cautions for A/D conversion trigger

- The count value of the A/D conversion trigger thinning out counter is incremented by 1 each time the same value is written (write access) to the TSnCCR4 register and TSnCCR5 register, and a valid A/D trigger is set under the same condition during count-up/down operation of the 16-bit counter. Output trigger is 1 pulse as well.
- The trough interrupt (INTTSnOD) does not occur in the PWM mode, PWM mode with dead time, 120° excitation mode, special 120° excitation mode, and special pattern output mode. Only the peak interrupt (INTTSnCD0) is valid.
- If the A/D conversion trigger is enabled when the INTTSnCC4 or INTTSnCC5 interrupt occurs during coun-up/down operation, the period of interrupt occurrence is different from the count state indicated by the TSnOPT0.TSnCUF bit (refer to *"Count-up flags (TSnCUF, TSnSUF)" on page 717*).
  - Count-up: TSnDTC0 < TSnCCR4, TSnCCR5 < TSnCCR0 - TsnDTC1 - 2</li>
  - Count-down: TSnDTC0 + 2 < TSnCCR4, TSnCCR5 < TSnCCR0 - TSnDTC1</li>



### 17.9 Error/warning Interrupt

#### 17.9.1 Error interrupt function

When a positive/negative phase simultaneous active is detected, the TSnTBF flag of the TSnOPT6 register is set and an error interrupt (INTTSnER) of timer Sn is generated. Switching ON/OFF of error detection in each phase (TOSn1/TOSn2, TOSn3/TOSn4, TOSn5/TOSn6) is possible with the TSnTBA2 to TSnTBA0 bits of the TSnIOC4 register after error interrupts are enabled (TSnEOC of TSnIOC4 register = 1).

The following table lists whether or not positive/negative simultaneous active error detection is possible in each mode.

| Mode                               | Positive/negative phase simultaneous active<br>error detection |
|------------------------------------|----------------------------------------------------------------|
| Interval timer mode                | -                                                              |
| External event count mode          | -                                                              |
| External trigger pulse output mode | -                                                              |
| One-shot pulse mode                | -                                                              |
| PWM mode                           | ٨                                                              |
| Free-running mode                  | -                                                              |
| Triangular-wave PWM mode           | ٨                                                              |
| High-accuracy T-PWM mode           | √                                                              |
| PWM mode with dead time            | ٨                                                              |
| 120° excitation mode               | ٨                                                              |
| Special pattern output mode        | $\checkmark$                                                   |

**Note**  $\sqrt{}$ : Detection possible

-: Detection not possible



Figure 17-46 Error interrupt (INTTSnER) output control circuit

**Caution** If an error interrupt occurs, release the error status during error interrupt servicing. An error interrupt will not occur thereafter until the error status is released.



#### (1) In PWM/special pattern output mode

When the dead time control function is not used (TSnDSE of TSnOPT0 register = 0 in PWM mode)
 As shown in *Figure 17-47 on page 753*, an error interrupt (INTTSnER) occurs when the TSnCCR1 and TSnCCR2 registers are set so that the active level is output from the TOSn1 and TOSn2 pins simultaneously. An error interrupt (INTTSnER) also occurs when the TSnCCR3 and TSnCCR4 registers are set so that the active level is output from the TOSn3 and TOSn4 pins simultaneously.



Figure 17-47 Generation of error interrupt (INTTSnER) (in PWM mode)

The following is the case where the output active level is switched by using the TSnOL1 and TSnOL2 bits of the TSnIOC0 register.



Figure 17-48 Generation of error interrupt in each active level (INTTSnER)



- When the dead time control function is used (TSnDSE of the TSnOPT0 register = 1 in PWM mode, or in special pattern output mode) Even if the timer output is inactive, an error interrupt occurs when the set conditions occurs simultaneously. For details refer to
  - "Dead time control in high-accuracy T-PWM mode" on page 826
  - "Dead time control in PWM mode with dead time" on page 847
  - "Dead time control in 120° excitation mode" on page 874
  - "Dead time control in special 120° excitation mode" on page 916
  - "Dead time control in special pattern output mode" on page 929

#### (2) Triangular-wave PWM mode

As shown in *Figure 17-49 on page 754*, an error interrupt (INTTSnER) occurs when the TSnCCR0 and TSnCCR1 registers are set so that the active level is output from the TOSn1 and TOSn2 pins simultaneously. An error interrupt (INTTSnER) also occurs when the TSnCCR3 and TSnCCR4 registers are set so that the active level is output from the TOSn3 and TOSn4 pins simultaneously.



Figure 17-49 Generation of error interrupt (INTTSnER) (in triangular PWM mode)

### (3) In high-accuracy T-PWM mode, PWM mode with dead time, or $120^\circ$ excitation mode

Errors caused by setting values of the compare register, the dead time setting register in the high-accuracy T-PWM mode, PWM mode with dead time, or 120° excitation mode do not occur.



#### (4) In special 120° excitation mode

An error interrupt (INTTSnER) occurs when timer Sn pattern registers 0 and 1 (TSnPAT0, TSnPAT1) are set so that the active level is output simultaneously. Refer to the caution on setting of the TSnPAT0 and TSnPAT1 registers in the special 120° excitation mode in "Difference between 120° excitation mode and special 120° excitation mode" on page 919 for details.

#### 17.9.2 Warning interrupt function

Timer S has the warning interrupt (INTTSnWN) function. A warning interrupt (INTTSnWN) is generated when any of the following conditions is detected. Refer to "Flags" on page 716 for details.

- When two or more simultaneous pin changes are detected at the TAPTSn2 to TAPTSn0 pins (Refer to "Noise detection flag (TSnNDF)" on page 722)
- When a reverse is detected at the TAPTSn2 to TAPTSn0 pins (Refer to "Pattern reverse detection flag (TSnPRF)" on page 726)
- When [0, 0, 0] or [1, 1, 1] is detected at the TAPTSn2 to TAPTSn0 pins (Refer to "Pattern error detection flag (TSnPEF)" on page 725)
- When the TSnPAT2 to TSnPAT0 pins are toggled three times or more during TSnSTCI0 and TSnSTCI1 signal triggers (Refer to "TAPTSn2 to TAPTSn0 pin abnormal toggle detection flag (TSnPTF)" on page 728)
- When the TSnSTCI0 and TSnSTCI1 signals are detected simultaneously (Refer to "TSnSTCI0, TSnSTCI1 signal simultaneous trigger detection flag (TSnTDF)" on page 730)
- When the phase relation between the input pattern (TAPTSn2 to TAPTSn0) and the output pattern (TSnOPF2 to TSnOPF0) is displaced (Refer to "Pattern phase difference detection flag (TSnPPF)" on page 731)



Figure 17-50 Error detection at TAPTSn2 to TAPTSn0 pins



### 17.10 Operation in Each Mode

|        | TSnCTL1   | Register | Timer Mode |                                                    |
|--------|-----------|----------|------------|----------------------------------------------------|
| TSnMD3 | TSnMD2    | TSnMD1   | TSnMD0     |                                                    |
| 0      | 0         | 0        | 0          | Interval timer mode                                |
| 0      | 0         | 0        | 1          | External event count mode                          |
| 0      | 0         | 1        | 0          | External trigger pulse output mode                 |
| 0      | 0         | 1        | 1          | One-shot pulse output mode                         |
| 0      | 1         | 0        | 0          | PWM mode                                           |
| 0      | 1         | 0        | 1          | Free-running mode                                  |
| 0      | 1         | 1        | 1          | Triangular-wave PWM mode                           |
| 1      | 0         | 0        | 0          | High-accuracy T-PWM mode <sup>Notes 1, 2</sup>     |
| 1      | 0         | 0        | 1          | PWM mode with dead time <sup>Note 1</sup>          |
| 1      | 0         | 1        | 0          | 120° excitation mode <sup>Notes 1, 2</sup>         |
| 1      | 0         | 1        | 1          | Special 120° excitation mode <sup>Notes 1, 2</sup> |
| 1      | 1         | 0        | 0          | Special pattern output mode                        |
|        | Other the | an above |            | Setting prohibited                                 |

| Table 17-32 | Mode list |
|-------------|-----------|
|-------------|-----------|

**Note 1.** The software output function can be used by setting TSnSOC of the TSnOPT4 register to 1.

2. 180° excitation control can be used by setting TSnADC of the TSnOPT5 register to 1.



## 17.10.1 Interval timer mode

In the interval timer mode, a compare match interrupt (INTTSnCC0) is generated upon a match between the TSnCCR0 register and 16-bit counter, and the 16-bit counter is then cleared. The interval time means the INTTSnCC0 generation interval.

In the interval timer mode, the 16-bit counter is cleared only upon a match between the 16-bit counter and the TSnCCR0 register.

The 16-bit counter is not cleared by using the TSnCCR1 to TSnCCR5 registers.

Setting values of the TSnCCR1 to TSnCCR5 registers are transferred to the TSnCCR1 to TSnCCR5 buffer registers to be compared with the 16-bit counter value, and a compare match interrupt (INTTSnCC1 to INTTSnCC5) then occurs.

The TSnCCR0 to TSnCCR5 registers can be rewritten with the anytime rewrite method regardless of the timer operation (TSnCE bit values of TSnCTL0 register).

Toggle output is performed from the TOSn0 to TOSn7 pins by setting the TSnOE0 to TSnOE7 bits of the TSnIOC0 register to 1.

**Note** The interval timer mode will be valid when TSnMD3 to TSnMD0 of the TSnCTL1 register are set to [0, 0, 0, 0].



Figure 17-51 Basic operation flow in interval timer mode

Note The 16-bit counter is not cleared upon a match with the TSnCCR1 to TSnCCR5 registers.



## (1) Interval timer mode operation list

## (a) Register rewriting

| Register              | Rewriting method | Rewriting during operation | Function      |
|-----------------------|------------------|----------------------------|---------------|
| TSnCCR0               | Anytime rewrite  | Possible                   | Compare value |
| TSnCCR1 to<br>TSnCCR3 | Anytime rewrite  | Possible                   | Compare value |
| TSnCCR4,<br>TSnCCR5   | Anytime rewrite  | Possible                   | Compare value |

## (b) Input pins

| Pin    | Function |
|--------|----------|
| TTRGSn | -        |
| TEVTSn | -        |

## (c) Output pins

| Pin            | Function                                                                 |
|----------------|--------------------------------------------------------------------------|
| TOSn0 to TOSn5 | Toggle output upon a compare match with the TSnCCR0 to TSnCCR5 registers |
| TOSn6, TOSn7   | -                                                                        |

## (d) Interrupt

| Interrupt                 | Function                                            |
|---------------------------|-----------------------------------------------------|
| INTTSnCC0 to<br>INTTSnCC5 | Compare match with the TSnCCR0 to TSnCCR5 registers |
| INTTSnOV                  | -                                                   |
| INTTSnER                  | -                                                   |
| INTTSnOD                  | -                                                   |
| INTTSnCD0                 | -                                                   |
| INTTSnWN                  | -                                                   |

## (e) Compare match timing

| Compare match         | Timing                                                                               |
|-----------------------|--------------------------------------------------------------------------------------|
| TSnCCR0               | Timing of switching 16-bit counter from TSnCCR0 to 0000H                             |
| TSnCCR1 to<br>TSnCCR5 | Timing of switching 16-bit counter from TSnCCR1 to TSnCCR5 to TSnCCR1 to TSnCCR5 + 1 |

Note "-" indicates an unused function in the interval timer mode.



Chapter 17

In case of D1 > D2 > D3, only value of the TSnCCR0 register is rewritten, without output from TOSn0 and TOSn1 (TSnOE0 = 0, TSnOE1 = 0, TSnOL0 = 0, and TSnOL1 = 1 for TSnIOC0 register)



Figure 17-52 Basic timing in interval timer mode (1/2)

- Note 1. D1, D2: TSnCCR0 register setting values (0000H to FFFFH) D3: TSnCCR1 register setting value (0000H to FFFFH)
  - Interval time =A: interval time (D1 + 1) × count clock cycle
     B: Interval time (D2 + 1) × count clock cycle
  - 3. TSnCCR2 to TSnCCR5 registers have the same functions as those of TSnCCR1.







Figure 17-53 Basic timing in interval timer mode (2/2)

- Note 1. D1: TSnCCR1 register setting value (0000H to FFFFH) D2: TSnCCR1 register setting value (0000H to FFFFH)
  - 2. Interval time = TOSn0, TOSn1 toggle time =  $(D1 + 1) \times (count clock cycle)$
  - 3. The TSnCCR2 to TSnCCR5 registers have the same functions as those of TSnCCR1.



## 17.10.2 External event count mode

In the external event count mode, the count-up operation starts with external event input (TEVTSn pin). At that time, the input signal from the TEVTSn pin is used as the count clock, regardless of the TSnEEE bit of the TSnCTL1 register. In the external event count mode, the 16-bit counter is cleared only upon a match between the 16-bit counter and the TSnCCR0 register. The 16-bit counter cannot be cleared by using the TSnCCR1 to TSnCCR5 registers. The setting values of the TSnCCR1 to TSnCCR5 registers are transferred to the TSnCCR1 to TSnCCR5 buffer registers to be compared with the 16-bit counter value, and a compare match interrupt (INTTSnCC1 to INTTSnCC5) then occurs.

The TSnCCR0 to TSnCCR5 registers can be rewritten with the anytime rewrite method regardless of the timer Sn operation (TSnCE bit value of TSnCTL0 register).

Toggle output is performed from the TOSn0 to TOSn7 pins by setting the TSnOE0 to TSnOE7 bits of the TSnIOC0 register to 1.

- Note 1. In the external event count mode, the edge detection count of the TEVTSn pin input is m + 1, where the TSnCCR0 register setting value is m.
  - 2. The external event count mode will be valid when TSnMD3 to TSnMD0 of the TSnCTL1 register are set to [0, 0, 0, 1].



Figure 17-54 Basic operation flow in external event count mode



## **Note** 1. Set other than TSnEES1 = 0 and TSnEES0 = 0.

2. The 16-bit counter is not cleared upon a match between the values of the 16bit counter and the TSnCCR1 to TSnCCR5 buffer registers.

## (1) External event count mode operation list

## (a) Register rewriting

| Register              | Rewriting<br>method | Rewriting during operation | Function      |
|-----------------------|---------------------|----------------------------|---------------|
| TSnCCR0               | Anytime rewrite     | Possible                   | Compare value |
| TSnCCR1 to<br>TSnCCR3 | Anytime rewrite     | Possible                   | Compare value |
| TSnCCR4, TSnCCR5      | Anytime rewrite     | Possible                   | Compare value |

## (b) Input pin

| Pin    | Function                                        |
|--------|-------------------------------------------------|
| TTRGSn | -                                               |
| TEVTSn | Timer count through external event count signal |

## (c) Output pin

| Pin            | Function                                                             |
|----------------|----------------------------------------------------------------------|
| TOSn0 to TOSn5 | Toggle output upon a compare match with TSnCCR0 to TSnCCR5 registers |
| TOSn6, TOSn7   | -                                                                    |

#### (d) Interrupt

| Interrupt                 | Function                                        |
|---------------------------|-------------------------------------------------|
| INTTSnCC0 to<br>INTTSnCC5 | Compare match with TSnCCR0 to TSnCCR5 registers |
| INTTSnOV                  | -                                               |
| INTTSnER                  | -                                               |
| INTTSnOD                  | -                                               |
| INTTSnCD0                 | -                                               |
| INTTSnWN                  | -                                               |

## (e) Compare match timing

| Compare match         | Timing                                                                                                    |
|-----------------------|-----------------------------------------------------------------------------------------------------------|
| TSnCCR0               | Timing of switching 16-bit counter from TSnCCR0 to 0000H                                                  |
| TSnCCR1 to<br>TSnCCR5 | Timing of switching 16-bit counter from <tsnccr1 to<br="">TSnCCR5&gt; to TSnCCR1 to TSnCCR5 + 1</tsnccr1> |

Note "-" indicates an unused function in the external event count mode.



In case of D1 > D2 > D3, rewriting of only TSnCCR0 register value, without output from TOSn0 and TOSn1





Figure 17-55 Basic operation timing in external event count mode (1/4)

- **Note** 1. After the timer Sn operation starts (TSnCE = 1), the 1st cycle count value will be 1 less than the value after the 2nd cycle.
  - D1, D2: TSnCCR0 register setting values (0000H to FFFFH) D3: TSnCCR1 register setting value (0000H to FFFFH)
  - 3. Event count = (Dk + 1)
  - 4. The TSnCCR2 to TSnCCR5 registers have the same functions as those of TSnCCR1.
  - 5. k = 1, 2



Chapter 17

In case of D1 = D2, TSnCCR0, without rewriting of TSnCCR1 register value, with output from TOSn0 and TOSn1 (TSnOE0 = 1, TSnOE1 = 1, TSnOL0 = 0, and TSnOL1 = 1 for TSnIOC0 register)



Figure 17-56 Basic operation timing in external event count mode (2/4)

- **Note** 1. After the timer Sn operation starts (TSnCE = 1), the 1st cycle count value will be 1 less than the value after the 2nd cycle.
  - D1: TSnCCR0 register setting value (0000H to FFFFH) D2: TSnCCR1 register setting value (0000H to FFFFH)
  - 3. Event count = (D1 + 1)
  - 4. The TSnCCR2 to TSnCCR5 registers have the same functions as those of TSnCCR1.

RENESAS

In case of D1 = D2, TSnCCR0, without rewriting of TSnCCR1 register value, with output from TOSn0 and TOSn1 (TSnOE0 = 1, TSnOE1 = 1, TSnOL0 = 0, and TSnOL1 = 1 for TSnIOC0 register) TSnEES1 = 1, TSnEES0 = 1 for TSnIOC register, both edges detected



Figure 17-57 Basic operation timing in external event count mode (3/4)

- Note 1. Event count = 1
  - 2. The TSnCCR2 to TSnCCR5 registers have the same functions as those of TSnCCR1.



In case of D1 = D2, without rewriting of TSnCCR0, TSnCCR1 register value, with output from TOSn0 and TOSn1





Figure 17-58 Basic operation timing in external event count mode (4/4)

- **Note** 1. After the timer Sn operation starts (TSnCE = 1), the 1st cycle count value will be 1 less than the value after the 2nd cycle.
  - 2. D1: TSnCCR0 register setting value (0001H) D2: TSnCCR1 register setting value (0001H)
  - 3. Event count = (Dk + 1)
  - 4. TOSn0 to TOSn5 are toggled when the 16-bit counter is set to 0001H.
  - 5. The TSnCCR2 to TSnCCR5 registers have the same functions as those of TSnCCR1.
  - 6. k = 1, 2



#### (2) Caution on timer output

In the external event count mode, the 16-bit counter is set to 0000H by setting the TSnCE bit to 1, regardless of TEVTSn pin edge detection. Output of the TOSn0 to TOSn5 pins will be active when the value is switched from 0000H to 0001H in the 1st cycle, and when the TSnCCR0 value is switched to 0000H in the 2nd and subsequent cycles. Therefore, the toggle width of the TOSn0 to TOSn5 pins differs between the 1st, 2nd and subsequent cycles.

## Differences between 1st cycle and 2nd cycle toggle width of TOSn0 to TOSn5

• TOSn0

Output is toggled at the TSnCCR0 count in the 1st counter cycle. In the 2nd and subsequent cycles, output is toggled at every TSnCCR0 + 1 count.

- TOSn1 to TOSn5
  - TSnCCR1 to TSnCCR5 = TSnCCR0

Output is toggled at the TSnCCR0 count in the 1st counter cycle. In the 2nd and subsequent cycles, output is toggled at every TSnCCR0 + 1 count.

- TSnCCR1 to TSnCCR5 = 0000H

Output is toggled at every TSnCCR0 + 1 count in all counter cycles.

- 0000H < TSnCCR1 to TSnCCR5 < TSnCCR0

Output is toggled at TSnCCR1 to TSnCCR5 counts in the 1st counter cycle. In the 2nd and subsequent cycles, output is toggled at every TSnCCR0 + 1 count.



## 17.10.3 External trigger pulse output mode

In the external trigger pulse output mode, when a duty is set with the TSnCCR1 to TSnCCR5 registers and a cycle is set with the TSnCCR0 register, and TSnCE is then set to 1, the 16-bit counter remains stopped with FFFFH and waits for external trigger input (TTRGSn pin). Count-up operation starts when a TTRGSn pin valid edge is detected or when the TSnEST bit of the TSnCTL1 register is set to 1. An external trigger pulse is output from the TOSn1 to TOSn5 pins. Toggle output is performed from the TOSn0 pin upon a match with the TSnCCR0 register value. A compare match interrupt (INTTSnCC0 to INTTSnCC5) occurs upon a match between the values of the 16-bit counter and the TSnCCR0 to TSnCCR5 registers during count operation.

The TSnCCR0 to TSnCCR5 registers can be rewritten by reload operation during count operation. Compare register values are reloaded upon a match between the values of the 16-bit counter and the TSnCCR0 register. If a TTRGSn pin valid edge is detected or if the TSnEST bit of the TSnCTL1 register is set to 1 during operation in the external trigger pulse output mode, the 16-bit counter is cleared and starts the count-up operation again. In this case, if the TOSn1 to TOSn5 pins are inactive, the output from the TOSn1 to TOSn5 pins are inactive even if an external trigger is input. If the TOSn1 to TOSn5 pins are inactive, the capture function cannot be used because the function of the TSnCCR0 to TSnCCR5 registers is fixed as a compare register.

- **Caution** 1. Clear the TSnEEE bit of the TSnCTL1 register to 0 in the external trigger pulse output mode.
  - 2. When the TSnRTE bit of the TSnOPT1 register is set to 1, reloading is executed by write to the TSnCCR1 register. In case of rewriting only the TSnCCR0 register value, the same value must also be written to the TSnCCR1 register. In this case, reloading is not performed if only the TSnCCR0 register is rewritten.
  - **Note** The external trigger pulse output mode will be valid when TSnMD3 to TSnMD0 of the TSnCTL1 register are set to [0, 0, 1, 0].





- Figure 17-59 Basic operation flow in external trigger pulse output mode
  - **Note** The 16-bit counter is not cleared upon a match between the values of the 16-bit counter and the TSnCCR1 to TSnCCR5 buffer registers.



## (1) External trigger pulse output mode operation list

#### (a) Register rewriting

| Register           | Rewriting method | Rewriting during operation | Function |
|--------------------|------------------|----------------------------|----------|
| TSnCCR0            | Reload           | Possible                   | Cycle    |
| TSnCCR1 to TSnCCR3 | Reload           | Possible                   | Duty     |
| TSnCCR4, TSnCCR5   | Reload           | Possible                   | Duty     |

## (b) Input pin

| Pin    | Function                                        |
|--------|-------------------------------------------------|
| TTRGSn | 16-bit counter clear and start by trigger input |
| TEVTSn | -                                               |

## (c) Output pin

| Pin            | Function                                                                     |  |
|----------------|------------------------------------------------------------------------------|--|
| TOSn0          | Toggle output by TSnCCR0 register compare match or<br>external trigger input |  |
| TOSn1 to TOSn5 | External trigger pulse waveform output                                       |  |
| TOSn6, TOSn7   | -                                                                            |  |

## (d) Interrupt

| Interrupt                 | Function                                        |
|---------------------------|-------------------------------------------------|
| INTTSnCC0 to<br>INTTSnCC5 | Compare match with TSnCCR0 to TSnCCR5 registers |
| INTTSnOV                  | -                                               |
| INTTSnER                  | -                                               |
| INTTSnOD                  | -                                               |
| INTTSnCD0                 | -                                               |
| INTTSnWN                  | -                                               |

## (e) Compare match timing

| Compare match         | Timing                                                                     |
|-----------------------|----------------------------------------------------------------------------|
| TSnCCR0               | Timing of switching 16-bit counter from TSnCCR0 to 0000H                   |
| TSnCCR1 to<br>TSnCCR5 | After match detection between 16-bit counter and TSnCCR1 to TSnCCR5 values |

Note "-" indicates an unused function in the external trigger pulse output mode.



In case of rewriting of TSnCCR0, TSnCCR1 register values, with output from TOSn0 and TOSn1 (TSnOE0 = 1, TSnOE1 = 1, TSnOL0 = 0, and TSnOL1 = 0 for TSnIOC0 register)



Figure 17-60 Basic operation timing in external trigger pulse output mode

- Note 1. D<sub>01</sub>, D<sub>02</sub>: TSnCCR0 register setting values (0000H to FFFH) D<sub>11</sub>, D<sub>12</sub>: TSnCCR1 register setting values (0000H to FFFFH)
  - TOSn1 (PWM) Duty = (TSnCCR1 register setting value) × (count clock cycle)

Cycle = (TSnCCR0 register setting value + 1) × (count clock cycle)

- 3. The TOSn0 pin is toggled immediately after the count start and when the 16-bit counter is cleared.
- 4. The TSnCCR2 to TSnCCR5 registers have the same functions as those of TSnCCR1.



## 17.10.4 One-shot pulse mode

In the one-shot pulse mode, a cycle is set with the TSnCCR0 register and the output compare value is set with the TSnCCR1 to TSnCCR5 registers. When the TSnCE bit of the TSnCTL0 register is set to 1, the 16-bit counter remains stopped with FFFFH and waits for external trigger input (TTRGSn pin). Count-up operation starts when the valid edge of an external trigger input (TTRGSn pin) is detected or when the TSnEST bit of the TSnCTL0 register is set to 1.

The TOSn1 to TOSn5 pins are active upon a match between the values of the 16-bit counter and the TSnCCR1 to TSnCCR5 registers. The TOSn1 to TOSn5 pins are inactive upon a match between the values of the 16-bit counter and the TSnCCR0 register, and the 16-bit counter is cleared to 0000H and then stops.

TOSn0 provides toggle output upon a match between the values of the 16-bit counter and the TSnCCR0 buffer register during count operation. A compare match interrupt (INTTSnCC0) occurs upon a match between the values of the 16-bit counter and the TSnCCR0 register, and a compare match interrupt (INTTSnCC1 to INTTSnCC5) occurs upon a match between the values of the 16-bit counter and the TSnCCR1 to TSnCCR5 buffer registers during count operation.

The TSnCCR0 to TSnCCR5 registers can be rewritten with the anytime rewrite method regardless of the timer Sn operation (TSnCE bit value of TSnCTL0 register).

Trigger input is ignored during 16-bit counter operation. The second trigger must be input while the 16-bit counter is stopped with 0000H.

In the one-shot pulse mode, the capture function cannot be used because the function of the TSnCCR0 to TSnCCR5 registers is fixed as a compare register.

- Caution Clear the TSnEEE bit of the TSnCTL1 register to 0 in the one-shot pulse mode.
  - **Note** The one-shot pulse mode will be valid when TSnMD3 to TSnMD0 of the TSnCTL1 register are set to [0, 0, 1, 1].





Figure 17-61 Basic operation flow in one-shot pulse mode

- **Note** The 16-bit counter is not cleared upon a match between the values of the 16-bit counter and the TSnCCR1 to TSnCCR5 buffer registers.
- **Caution** The 16-bit counter is not be cleared and trigger input is ignored even if the trigger is input during count-up operation by the 16-bit counter.



## (1) One-shot pulse mode operation list

## (a) Register rewriting

| Register              | Rewriting method | Rewriting During<br>Operation | Function           |
|-----------------------|------------------|-------------------------------|--------------------|
| TSnCCR0               | Anytime rewrite  | Possible                      | Cycle              |
| TSnCCR1 to<br>TSnCCR3 | Anytime rewrite  | Possible                      | Output delay value |
| TSnCCR4,<br>TSnCCR5   | Anytime rewrite  | Possible                      | Output delay value |

#### (b) Input pin

| Pin    | Function                              |
|--------|---------------------------------------|
| TTRGSn | 16-bit counter start by trigger input |
| TEVTSn | -                                     |

## (c) Output pin

| Pin            | Function                                                                                   |  |
|----------------|--------------------------------------------------------------------------------------------|--|
| TOSn0          | Active at count start, inactive upon match of TSnCCR0 register                             |  |
| TOSn1 to TOSn5 | Active upon match of TSnCCR1 to TSnCCR5 registers, inactive upon match of TSnCCR0 register |  |
| TOSn6, TOSn7   | -                                                                                          |  |

## (d) Interrupt

| Interrupt                 | Function                                      |
|---------------------------|-----------------------------------------------|
| INTTSnCC1 to<br>INTTSnCC5 | Compare match of TSnCCR1 to TSnCCR5 registers |
| INTTSnOV                  | -                                             |
| INTTSnER                  | -                                             |
| INTTSnOD                  | -                                             |
| INTTSnCD0                 | -                                             |
| INTTSnWN                  | -                                             |

### (e) Compare match timing

| Compare match         | Timing                                                                                     |  |
|-----------------------|--------------------------------------------------------------------------------------------|--|
| TSnCCR0               | Timing of switching 16-bit counter from TSnCCR0 to 0000H                                   |  |
| TSnCCR1 to<br>TSnCCR5 | After detection of match between values of 16-bit counter and TSnCCR1 to TSnCCR5 registers |  |

**Note** 1. "-" indicates an unused function in the one-shot pulse mode.

**2.** m = 1 to 5



# (TSnOE0 = 1, TSnOE1 = 1, TSnOL0 = 1, and TSnOL1 = 1 for TSnIOC0 register, TSnEES1 = 0 and TSnEES0 = 1 for TSnIOC2 register, rising edge detect

TSnEES1 = 0 and TSnEES0 = 1 for TSnIOC2 register, rising edge detected)





- **Note 1.** The 16-bit counter starts count-up operation when the TSnEST bit of the TSnCTL1 register is set to 1 or when a pulse is input from the TTRGSn pin.
  - 2. D0: TSnCCR0 register setting value (0000H to FFFFH) D1: TSnCCR1 register setting value (0000H to FFFFH)
  - TOSn1 (output delay) = (TSnCCR1 register setting value) × (count clock cycle)
     TOSn1 (output pulse width) = {(TSnCCR0 register setting value + 1) (TSnCCR1 register setting value)} × (count clock cycle)
  - 4. The TOSn2 to TOSn5 pins have the same functions as those of the TOSn1 pin.



## 17.10.5 PWM mode

In the PWM mode, when a duty is set with the TSnCCR1 to TSnCCR5 registers and a cycle is set with the TSnCCR0 register, and the TSnCE bit of the TSnCTL0 register is then set to 1, duty variable type PWM is output from the TOSn1 to TOSn5 pins.

The TOSn1 to TOSn5 pins are active when count-up operation starts, and inactive upon a match between the values of the 16-bit counter and the TSnCCR1 to TSnCCR5 registers. Then, the TOSn1 to TOSn5 pins are active upon a match with the TSnCCR0 register value. The TOSn0 pin provides toggle output upon a match with the TSnCCR0 buffer register.

A compare match interrupt (INTTSnCC0 to INTTSnCC5) occurs upon a match between the values of the 16-bit counter and the TSnCCR0 to TSnCCR5 registers during count operation.

The TSnCCR0 to TSnCCR5 registers can be rewritten during count operation. Compare register values are reloaded upon a match between the 16-bit counter and TSnCCR0 register values.

The TSnCCR0 to TSnCCR5 registers can be rewritten with the reload write method, regardless of the timer Sn operation (TSnCE bit value of TSnCTL0 register).

In the PWM mode, the capture function cannot be used because the function of the TSnCCR0 to TSnCCR5 registers is fixed as a compare register.

**Caution** When the TSnRTE bit of the TSnOPT1 register is set to 1, reloading is executed by write to the TSnCCR1 register. In case of rewriting only the TSnCCR0 register value, the same value must also be written to the TSnCCR1 register. In this case, reloading is not performed if only the TSnCCR0 register is rewritten.

**Note** The PWM mode will be valid when TSnMD3 to TSnMD0 of the TSnCTL1 register are set to [0, 1, 0, 0].





In case of TSnCCR0, TSnCCR1 to TSnCCR5 values not rewritten during timer operation



Figure 17-63 Basic operation flow in PWM mode (1/2)







Figure 17-64 Basic operation flow in PWM mode (2/2)

**Note** Although the timing of <2> may differ according to the TSnCCR register value or the timing of rewriting <1> and <3>, be sure to perform <3> last.



## (1) PWM mode operation list

## (a) Register rewriting

| Register              | Rewriting Method | Rewriting During<br>Operation          | Function         |
|-----------------------|------------------|----------------------------------------|------------------|
| TSnCCR0               | Reload           | Possible                               | Cycle            |
| TSnCCR1 to<br>TSnCCR3 | Reload           | Possible                               | Duty             |
| TSnCCR4,<br>TSnCCR5   | Reload           | Possible                               | Duty             |
| TSnDTC0,<br>TSnDTC1   | Reload           | Conditionally possible <sup>Note</sup> | Cycle, dead time |

## (b) Input pin

| Pin    | Function |
|--------|----------|
| TTRGSn | -        |
| TEVTSn | -        |

## (c) Output pin

| Pin            | Function                                                    |  |
|----------------|-------------------------------------------------------------|--|
| TOSn0          | Toggle output by compare match of TSnCCR0 register          |  |
| TOSn1 to TOSn5 | PWM output by compare match of TSnCCR1 to TSnCCR5 registers |  |
| TOSn6          | -                                                           |  |
| TOSn7          | Pulse output by A/D conversion trigger                      |  |

## (d) Interrupt

| Interrupt                 | Function                                                |  |
|---------------------------|---------------------------------------------------------|--|
| INTTSnCC0 to<br>INTTSnCC5 | Compare match of TSnCCR0 to TSnCCR5 registers           |  |
| INTTSnOV                  | -                                                       |  |
| INTTSnER                  | Error                                                   |  |
| INTTSnOD                  | -                                                       |  |
| INTTSnCD0                 | Peak interrupt (simultaneous occurrence with INTTSnCC0) |  |
| INTTSnWN                  | -                                                       |  |

## (e) Compare match timing

| Compare Match         | Timing                                                                                     |
|-----------------------|--------------------------------------------------------------------------------------------|
| TSnCCR0               | Timing of switching 16-bit counter from TSnCCR0 to 0000H                                   |
| TSnCCR1 to<br>TSnCCR5 | After detection of match between values of 16-bit counter and TSnCCR1 to TSnCCR5 registers |

**Note** Refer to *"Rewriting of TSnDTC0 and TSnDTC1 registers" on page 827* for details.



## (f) Output condition

| Output           | Condition                      |
|------------------|--------------------------------|
| Duty 0% output   | TSnCCRm = 0000H                |
| Duty 100% output | TSnCCRm = TSnCCR0 + 1          |
| Dead time check  | TSnDSE of TSnOPT0 register = 1 |

**Note** 1. "-" indicates an unused function in the PWM mode.

2. m = 1 to 5

Only TSnCCR1 value rewritten, with output from TOSn0 and TOSn1 (TSnOE0 = 1, TSnOE1 = 1, TSnOL0 = 0, and TSnOL1 = 0 for TSnIOC0 register)



Figure 17-65 Basic operation timing in PWM mode (1/2)

- Note 1. D<sub>00</sub>: TSnCCR0 register setting value (0000H to FFFH) D<sub>10</sub>, D<sub>11</sub>, D<sub>12</sub>, D<sub>13</sub>: TSnCCR1 register setting values (0000H to FFFH)
  - TOSn1 (PWM) duty = (TSnCCR1 register setting value) × (count clock cycle)
     TOSn1 (PWM) cycle = (TSnCCR0 register setting value + 1) × (count clock cycle)
  - 3. TOSn0 is toggled immediately after count start and with (TSnCCR0 register setting value + 1) × (count clock cycle)
  - 4. The TOSn2 to TOSn5 pins have the same functions as those of the TOSn1 pin.

RENESAS

Only TSnCCR1 value rewritten, with output from TOSn0 and TOSn1 (TSnOE0 = 1, TSnOE1 = 1, TSnOL0 = 0, and TSnOL1 = 0 for TSnIOC0 register)



Figure 17-66 Basic operation timing in PWM mode (2/2)

- **Note 1.** Since the TSnCCR1 register has not been written, this value is not reloaded to the TSnCCR0 buffer register.
  - D<sub>00</sub>, D<sub>01</sub>, D<sub>02</sub>, D<sub>03</sub>: TSnCCR0 register setting values (0000H to FFFFH) D<sub>10</sub>, D<sub>11</sub>, D<sub>12</sub>, D<sub>13</sub>: TSnCCR1 register setting values (0000H to FFFFH)
  - **3.** The TOSn0 and TOSn1 pins become active level when the timer starts counting.
  - 4. The TOSn2 to TOSn5 pins have the same functions as those of the TOSn1 pin.



## (2) Reload/interrupt thinning out functions in PWM mode

The reload thinning out function and interrupt thinning out function are enabled by setting TSnRTE = 1, TSnICE = 1, and TSnRDE = 1 for the TSnOPT1 register, and TSnID4 to TSnID0.

The interrupt thinning out function is enabled by setting TSnRTE = 1, TSnRDE = 0, and TSnID4 to TSnID0.

#### (3) Dead time control in PWM mode

In the PWM mode, dead time control is enabled by setting the dead time value to the TSnDTC0 and TSnDTC1 registers and setting TSnDSE of the TSnOPT0 register to 1. The dead time can be controlled at the timing of switching the TOSn1, TOSn2, TOSn3 and TOSn4 pins.

#### Table 17-33 Dead time in PWM mode

| Switch timing                                                    | Dead time              |
|------------------------------------------------------------------|------------------------|
| TOSn1: High level to low level<br>TOSn2: Low level to high level | TSnDTC1 register value |
| TOSn2: High level to low level<br>TOSn1: Low level to high level | TSnDTC0 register value |
| TOSn3: High level to low level<br>TOSn4: Low level to high level | TSnDTC1 register value |
| TOSn4: High level to low level<br>TOSn3: Low level to high level | TSnDTC0 register value |





The dead time counter starts at the falling edge of TOSn1 during the period of (1). Then, TOSn2 normally becomes active when the 16-bit counter becomes 0000H, but since the dead time counter is operating, it becomes active when the dead time count operation is finished.

The dead time counter starts at the falling edge of TOSn2 during the period of (2). Then, TOSn1 normally becomes active when the 16-bit counter becomes 0000H, but since the dead time counter is operating, it becomes active when the dead time count operation is finished.

The dead time counter starts at the falling edge of TOSn1 during the period of (3). Then, TOSn2 becomes active when the 16-bit counter becomes 0000H after the dead time counter finishes the count operation.

The dead time counter starts at the falling edge of TOSn2 during the period of



(4). Then, TOSn1 becomes active when the 16-bit counter becomes 0000H after the dead time counter finishes the count operation.

- Note 1. The active level of TOSn1 and TOSn2 is high level.
  - 2. The active level of TOSn3 and TOSn4 is high level.



Figure 17-68 Dead time control between TOSn1 and TOSn2 pins (2/2)

The dead time counter starts at the falling edge of TOSn1 during the period of (1). Then, TOSn2 normally becomes active when the 16-bit counter becomes 0000H, but since the dead time counter is operating, it becomes active when the dead time count operation is finished. In this case, however, TOSn2 becomes inactive upon a compare match, because a TSnCCR2 compare match occurs before the dead time counter operation finishes.

$$\label{eq:timestable} \begin{split} &TSnCCR1 + TSnDTC1 \geq TSnCCR0 + TSnCCR2 \mbox{ (TOSn2 remains inactive)}.\\ &TSnCCR2 + TSnDTC0 \geq TSnCCR0 + TS0CCR1 \mbox{ (TOSn1 remains inactive)}. \end{split}$$

TOSn1 becomes active during the period of (2) because dead time control is not in operation. In this case, however, an INTTSnER interrupt occurs because TSnCCR1 and TSnCCR2 are set so that TOSn1 and TOSn2 rise simultaneously.

The dead time counter starts at the falling edge of TOSn1 during the period of (3). TOSn2 becomes active when the dead time counter operation is finished. TOSn2 becomes inactive upon a match of TSnCCR2.

The dead time counter starts at the falling edge of TOSn2 during the period of (4). Then, the 16-bit counter is cleared and the next PWM cycle is output. TOSn2 becomes active because TOSn1 is in the dead time period. In this case, however, an INTTSnER interrupt occurs because TSnCCR1 and TSnCCR2 are set so that TOSn1 and TOSn2 rise simultaneously. The dead time counter starts at the falling edge of TOSn2 during the period of (5). TOSn1 does not become active even after the dead time counter operation is finished, because TSnCCR1 is smaller than TOSn2 and is already inactive.

- Note 1. The active level of TOSn1 and TOSn2 is high level.
  - 2. The active level of TOSn3 and TOSn4 is high level.





Figure 17-69 Duty 100% output

As shown in *Figure 17-69 on page 784*, when TOSn2 is set to make duty 100% output (TSnCCR2  $\geq$  TSnCCR0 + 1), the TOSn1 output is fixed at the low level. This means that the control masks the TOSn1 active condition, because TOSn2 is already active when TOSn1 becomes active. In this case, an INTTSnER interrupt occurs because of the setting to make TOSn1 and TOSn2 high level simultaneously.

- Note 1. The active level of TOSn1 and TOSn2 is high level.
  - 2. The active level of TOSn3 and TOSn4 is high level.

## (4) Dead time rewriting by PWM mode operation

In the PWM mode, timer Sn dead time setting registers (TSnDTC0, TSnDTC1) can be rewritten during count operation. The new setting for the dead time becomes valid when the value is reloaded. The value cannot be changed with the anytime rewrite method.

Change of the dead time will be valid at the culled reload timing when the reload thinning out function (TS0RDE bit of TSnOPT1 register = 1) is used in the PWM mode.

TS0CCR1 must be written while the TS0RDE bit of the TSnOPT1 register is 1 in order to enable the reload timing.



#### (5) Other timer outputs in PWM mode

## (a) TOSn5 pin

PWM output can be performed in the same manner as the TOSn1 to TOSn4 pins by setting the TSnCCR5 register. The dead time cannot be set.

#### (b) TOSn0 and TOSn6 pins

The TOSn0 pin repeats toggle operation in every PWM cycle. The TOSn6 pin outputs the inactive level.

#### (c) INTTSnER interrupt

The INTTSnER interrupt occurrence conditions vary depending on the TSnDSE bit setting in the TSnOPT0 register. TSnTBF is set to 1 when an interrupt occurs.

| TSnDSE of TSnOPT0<br>register        | TSnTBF of TSnOPT6<br>register                             | INTTSnER                                                                                                                 |
|--------------------------------------|-----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|
| 0<br>(Dead time control<br>disabled) | Set when timer outputs<br>become active<br>simultaneously | An error interrupt is output while<br>timer outputs become active<br>simultaneously and output active<br>simultaneously. |
| 1<br>(Dead time control<br>enabled)  | Set when timer outputs become active simultaneously       | An error interrupt is output when<br>a condition that sets timer<br>outputs simultaneously occurs.                       |

When the TSnDSE bit of the TSnOPT0 register is 1, or the TSnTBA0 and TSnTBA1 bits of the TSnIOC4 register are 1, occurrence of a condition that sets positive/negative phase simultaneously for the TOSn1 and TOSn3 pins and the TOSn2 and TOSn4 pins is the error interrupt occurrence condition. Therefore, an error interrupt occurs when a positive/negative phase simultaneous setting condition occurs even when TSnOE1 and TSnOE2 of the TSnIOC0 register are set to 0 and the TOSn1 and TOSn2 pins are fixed at the inactive level. Moreover, the positive/negative phase simultaneous active detection flag is also set.

Clear TSnTBA0 and TSnTBA1 to 0 to prevent the above situation.



## 17.10.6 Free-running mode

In the free-running mode, the 16-bit counter counts from 0000H to FFFFH when the TSnCE bit of the TSnCTL0 register is set to 1. When the 16-bit counter overflows from FFFFH to 0000H, the overflow flag (TSnOVF) is set to 1, an overflow interrupt (INTTSnOV) occurs, and the count is then cleared. Count operation in the free-running mode continues until TSnCE is cleared to 0. A compare match interrupt (INTTSnCC0 to INTTSnCC5) occurs upon a match between the values of the 16-bit counter and the TSnCCR0 to TSnCCR5 registers during the count operation. The TSnCCR0 to TSnCCR5 registers can be rewritten with the anytime rewrite method regardless of the timer Sn operation (TSnCE bit value). TOSn0 to TOSn5 become active immediately after the operation starts and perform toggle output when a match interrupt with the compare register occurs.

- **Caution** The overflow flag (TSnOVF) is not cleared only by being read, but cleared when 0 is written or the operation stops (TSnCE = 0).
  - **Note** The free-running mode will be valid when TSnMD3 to TSnMD0 of the TSnCTL1 register are set to [0, 1, 0, 1].





- Figure 17-70 Basic operation flow in free-running mode
  - **Note** The 16-bit counter is not cleared upon a match between the values of the 16-bit counter and the TSnCCR0 to TSnCCR5 buffer registers.



## (1) Free-running mode operation list

## (a) Register rewriting

| Register              | Rewriting<br>method | Rewriting during operation | Function      |
|-----------------------|---------------------|----------------------------|---------------|
| TSnCCR0               | Anytime rewrite     | Possible                   | Compare value |
| TSnCCR1 to<br>TSnCCR3 | Anytime rewrite     | Possible                   | Compare value |
| TSnCCR4, TSnCCR5      | Anytime rewrite     | Possible                   | Compare value |

## (b) Input pin

| Pin    | Function |
|--------|----------|
| TTRGSn | -        |
| TEVTSn | -        |

## (c) Output pin

| Pin            | Function                                                       |
|----------------|----------------------------------------------------------------|
| TOSn0 to TOSn5 | Toggle output by compare match of TSnCCR0 to TSnCCR5 registers |
| TOSn6, TOSn7   | -                                                              |

## (d) Interrupt

| Interrupt                 | Function                                     |
|---------------------------|----------------------------------------------|
| INTTSnCC0 to<br>INTTSnCC5 | Compare match of TSnCCR0 to TSnCCR5 register |
| INTTSnOV                  | Overflow                                     |
| INTTSnER                  | -                                            |
| INTTSnOD                  | -                                            |
| INTTSnCD0                 | -                                            |
| INTTSnWN                  | -                                            |

## (e) Compare match timing

| Compare match         | Timing                                                                                         |
|-----------------------|------------------------------------------------------------------------------------------------|
| TSnCCR0               | Timing of switching 16-bit counter from TSnCCR0 to 0000H                                       |
| TSnCCR1 to<br>TSnCCR5 | Timing of switching 16-bit counter from "TSnCCR1 to<br>TSnCCR5" to<br>"TSnCCR1 to TSnCCR5 + 1" |

#### **Note** "-" indicates an unused function in the free-running mode.



## Chapter 17

# TSnCCR0, TSnCCR1 register values rewritten, with output from TOSn0 and TOSn1 (TSnOE0 = 1, TSnOE1 = 1, TSnOL0 = 0, and TSnOL1 = 0 for TSnIOC0 register)



Figure 17-71 Basic operation flow in free-running mode

- Note 1. D<sub>00</sub>, D<sub>01</sub>: TSnCCR0 register setting values (0000H to FFFH) D<sub>10</sub>, D<sub>11</sub>: TSnCCR1 register setting values (0000H to FFFFH)
  - 2. The TOSn0 and TOSn1 pins become active level when the timer starts counting.
  - 3. The TOSn2 to TOSn5 pins have the same functions as those of the TOSn1 pin.



## 17.10.7 Triangular-wave PWM mode

In the triangular-wave PWM mode, when a duty is set with the TSnCCR1 to TSnCCR5 registers, a cycle is set with the TSnCCR0 register and the TSnCE bit of the TSnCTL0 register is then set to 1, duty variable type triangular-wave PWM output is provided from the TOSn1 to TOSn5 pins. TOSn0 performs toggle output upon a match of the TSnCCR0 buffer register and when a 16-bit counter underflow occurs. A compare match interrupt (INTTSnCC0 to INTTSnCC5) occurs upon a match between the values of the 16-bit counter and the TSnCCR0 to TSnCCR5 registers during count operation. Also, a trough interrupt (INTTSnOD) occurs when a 16-bit counter underflow occurs. The TSnCCR0 to TSnCCR5 registers can be rewritten during count operation. Compare register values are reloaded when a 16-bit counter underflow occurs.

Writing to the TSnCCR1 register enables the next reload timing. In the triangular-wave PWM mode, the capture function cannot be used because the function of the TSnCCR0 to TSnCCR5 registers is fixed as a compare register.

- Note 1. Set a value of  $0 \le TSnCCR0 \le FFFEH$  to the TSnCCR0 register in the triangular-wave PWM mode.
  - 2. Set the TSnRBE bit of the TSnOPT1 register to 1 in the triangular-wave PWM mode. Reload does not occur by clearing TSnRBE to 0.
  - **3.** The triangular-wave PWM mode will be valid when TSnMD3 to TSnMD0 of the TSnCTL1 register are set to [0, 1, 1, 1].





- Figure 17-72 Basic operation flow in triangular-wave PWM mode
  - **Note** The 16-bit counter is not cleared upon a match between the values of the 16-bit counter and the TSnCCR0 to TSnCCR5 buffer registers.



## (1) Triangular-wave PWM mode operation list

## (a) Register rewriting

| Register           | Rewriting method | Rewriting during operation | Function     |
|--------------------|------------------|----------------------------|--------------|
| TSnCCR0            | Reload           | Possible                   | 1/2 of cycle |
| TSnCCR1 to TSnCCR3 | Reload           | Possible                   | 1/2 of duty  |
| TSnCCR4, TSnCCR5   | Reload           | Possible                   | 1/2 of duty  |

## (b) Input pin

| Pin    | Function |
|--------|----------|
| TTRGSn | -        |
| TEVTSn | -        |

## (c) Output pin

| Pin            | Function                                                                              |
|----------------|---------------------------------------------------------------------------------------|
| TOSn0          | Inactive during 16-bit counter count-up operation Active during count-down operation. |
| TOSn1 to TOSn5 | PWM output by compare match of TSnCCR1 to TSnCCR5 registers                           |
| TOSn6          | -                                                                                     |
| TOSn7          | Pulse output by A/D conversion trigger                                                |

## (d) Interrupt

| Interrupt              | Function                                      |
|------------------------|-----------------------------------------------|
| INTTSnCC0 to INTTSnCC5 | Compare match of TSnCCR0 to TSnCCR5 registers |
| INTTSnOV               | -                                             |
| INTTSnER               | Error                                         |
| INTTSnOD               | Trough interrupt                              |
| INTTSnCD0              | -                                             |
| INTTSnWN               | -                                             |

## (e) Compare match timing

| Compare match      | Timing                                                                                   |
|--------------------|------------------------------------------------------------------------------------------|
| TSnCCR0            | Timing of switching 16-bit counter from TSnCCR0<br>toTSnCCR0 – 1                         |
| TSnCCR1 to TSnCCR5 | Timing of switching 16-bit counter from "TSnCCR1 to TSnCCR5" to "TSnCCR1 to TSnCCR5 + 1" |

## (f) Output condition

| Output                | Condition                  |
|-----------------------|----------------------------|
| Duty 0% output        | TSnCCRm = TSnCCR0 + 1      |
| Duty 100% output      | TSnCCRm = 0000H            |
| Toggle at peak/trough | $TSnCCRm \geq TSnCCR0 + 2$ |

Note 1. "-" indicates an unused function in the triangular-wave PWM mode.

```
2. m = 1 to 5
```



Chapter 17





Figure 17-73 Basic operation timing in triangular-wave PWM mode

- Note 1. D<sub>00</sub>, D<sub>01</sub>, D<sub>02</sub>: Triangular-wave cycle (TSnCCR0 + 1)  $\times$  2 D<sub>10</sub>, D<sub>11</sub>, D<sub>12</sub>: PWM duty (TSnCCR0 - TCnCCR1 + 1)  $\times$  2 Count-up: 0000H to D<sub>00</sub> Count-down: (D<sub>00</sub>- 0001H
  - 2. The TOSn2 to TOSn5 pins have the same functions as those of the TOSn1 pin.



## (2) Reload/interrupt thinning out function in triangular-wave PWM mode

The reload thinning out function and interrupt thinning out function are enabled by setting TSnRTE = 1, TSnICE = 1, and TSnRDE = 1 in the TSnOPT1 register, and TSnID4 to TSnID0. The interrupt thinning out function is enabled by setting TSnRTE = 1, TSnRDE = 0, and TSnID4 to TSnID0.



# 17.10.8 High-accuracy T-PWM mode

In the high-accuracy T-PWM mode, 6-phase PWM is generated by using the 16-bit counter (up/down,  $\pm 2$  counts, real 15-bit) and four 16-bit compare registers (LSB = additional pulse control bit).

The carrier wave value calculated with "TSnCCR0 – TSnDTC0 – TSnDTC1" is set to the TSnCCR0 register. A duty of U, V, and W-phase voltage data signal is set with the TSnCCR1 to TSnCCR3 registers. A dead time is set with the TSnDTC0 and TSnDTC1 registers. The TSnDTC0 register can set the dead time of negative phase (OFF) to positive phase (ON). TSnDTC1 can sets the dead time of positive phase (OFF) to negative phase (ON).

The 16-bit counter performs count-up operation using the TSnDTC0 register value as the minimum value, and count-down operation upon a match with the maximum value indicated by TSnCCR0 –TSnDTC1.

The 10-bit dead time counters (TSnDTT1 to TSnDTT3) reloads the value set to the TSnDTC0 and TSnDTC1 registers upon a match between the values of the TSnDTT1 to TSnDTT3 and TSnCCR1 to TSnCCR3 registers to perform count-down operation.

A compare match interrupt signal (INTTSnCC1 to INTTSnCC5) occurs upon a match between the values of the 16-bit counter and the TSnCCR1 to TSnCCR5 registers.

**Note** The high-accuracy T-PWM mode will be valid when TSnMD3 to TSnMD0 of the TSnCTL1 register are set to [1, 0, 0, 0].



Figure 17-74 Block diagram of high-accuracy T-PWM mode





- Figure 17-75 Basic operation flow in high-accuracy T-PWM mode
  - **Note 1.** The 16-bit counter is not cleared upon a match between the values of the 16-bit counter and the TSnCCR0 to TSnCCR5 buffer registers.
    - 2. Only when TSnDTC = 0000H



# (1) High accuracy T-PWM mode operation list

## (a) Register rewriting

| Register              | Rewriting method          | Rewriting During<br>Operation               | Function                                              |
|-----------------------|---------------------------|---------------------------------------------|-------------------------------------------------------|
| TSnCCR0               | Reload/anytime rewrite    | Possible                                    | Cycle                                                 |
| TSnCCR1 to<br>TSnCCR3 | Reload/anytime rewrite    | Possible                                    | PWM duty                                              |
| TSnCCR4,<br>TSnCCR5   | Reload/anytime<br>rewrite | Possible                                    | PWM duty<br>(selectable as A/D<br>conversion trigger) |
| TSnDTC0,<br>TSnDTC1   | Reload                    | Conditionally<br>possible <sup>Note 1</sup> | Cycle, dead time                                      |

## (b) Input pin

| Pin    | Function |
|--------|----------|
| TTRGSn | -        |
| TEVTSn | -        |

# (c) Output pin

| Pin   | Function                                                                                         |
|-------|--------------------------------------------------------------------------------------------------|
| TOSn0 | Inactive during counting up, active during counting down by 16-bit counter or 16-bit sub-counter |
| TOSn1 | PWM output (with dead time) upon a TSnCCR1 compare match                                         |
| TOSn2 | Negative phase output for TOSn1 <sup>Note 2</sup>                                                |
| TOSn3 | PWM output (with dead time) upon a TSnCCR2 compare match                                         |
| TOSn4 | Negative phase output for TOSn3 <sup>Note 2</sup>                                                |
| TOSn5 | PWM output (with dead time) upon a TSnCCR3 compare match                                         |
| TOSn6 | Negative phase output for TOSn5 <sup>Note 2</sup>                                                |
| TOSn7 | Pulse output by A/D conversion trigger                                                           |

- **Note 1.** Refer to *"Rewriting of TSnDTC0 and TSnDTC1 registers" on page 827* for details.
  - 2. The output level of TOSn2, TOSn4, and TOSn6 will be switched to active level by setting TSnCE of the TSnCTL0 register to 1 while TSnOE2, TSnOE4, and TSnOE6 are 1, and TSnOL2, TSnOL4, and TSnOL6 are 0 in the TSnIOC0 register.
  - 3. "-" indicates an unused function in the high-accuracy T-PWM mode.



# (d) Interrupt

| Interrupt                 | Function                                  |
|---------------------------|-------------------------------------------|
| INTTSnCC0                 | INTTSnCC0 compare match <sup>Note 1</sup> |
| INTTSnCC1 to<br>INTTSnCC5 | TSnCCR1 to TSnCCR5 compare match          |
| INTTSnOV                  | Overflow <sup>Note 2</sup>                |
| INTTSnER                  | Error                                     |
| INTTSnOD                  | Trough interrupt                          |
| INTTSnCD0                 | Peak interrupt                            |
| INTTSnWN                  | Warning interrupt                         |

# (e) Compare match timing

| Compare match         | Timing                                                                                   |
|-----------------------|------------------------------------------------------------------------------------------|
| TSnCCR0               | Timing of switching 16-bit counter from TSnCCR0 to TSnCCR0<br>- 2                        |
| TSnCCR1 to<br>TSnCCR5 | Timing of switching 16-bit counter from "TSnCCR1 to TSnCCR5" to "TSnCCR1 to TSnCCR5 + 1" |

# (f) Output condition

| Output           | Condition         |
|------------------|-------------------|
| Duty 0% output   | TSnCCRm = TSnCCR0 |
| Duty 100% output | TSnCCRm = 0000H   |

# Note 1. Only when TSnDTC1 = 0000H

- 2. When the TSnCCR0, TSnDTC0, and TSnDTC1 registers are incorrectly set
- 3. "-" indicates an unused function in the high-accuracy T-PWM mode.
- 4. m = 1 to 3



### (2) Various setting in high-accuracy T-PWM mode

### (a) Mode setting

The high-accuracy T-PWM mode is set by setting TSnMD3 to TSnMD0 of the TSnCTL1 register to [1, 0, 0, 0].

### (b) Output level/output enable setting

Output level/output is enabled by setting the TSnOL0 to TSnOL7 and TSnOE0 to TSnOE7 bits of the TSnIOC0 register.

The TOSn0 pin outputs the status of count-up/down operation by the 16-bit counter and 16-bit sub-counter. The 16-bit counter and 16-bit sub-counter is switched with the TSnTOS bit of the TSnOPT7 register.

The TOSn7 pin outputs pulses by A/D conversion trigger. Set this as necessary.

### (c) Enabling error interrupt occurrence

Occurrence of an error interrupt (INTTSnER) when positive/negative phase simultaneous active is detected is enabled by setting the TSnEOC bit of the TSnIOC4 register to 1.

In the high-accuracy T-PWM mode, the positive/negative phases do not become active simultaneously by setting any value to the TSnCCR0 to TSnCCR3 registers.

## (d) Register rewrite timing setting with reload function

Reload (batch rewrite) or anytime rewrite (default "0" reload) will be executed for registers with the reload function by using the TSnCMS bit of the TSnOPT0 register. Be sure to set the TSnRTE or TSnRBE bit of the TSnOPT1 register to 1 to execute the reload operation.

No reload timings will occur when both the TSnRTE and TSnRBE bits are 0. In case of anytime rewrite, unexpected output may occur depending on the rewrite timing.

Refer to (a) to (c) in *"Anytime rewrite mode" on page 693* when using the anytime rewrite function.

#### (e) Interrupt and thinning out function setting

The interrupt and thinning out functions can be set with the TSnOPT1 register. Set the TSnICE bit to 1 to generate peak interrupts (INTTSnCD0), and set the TSnIOE bit to 1 to generate trough interrupts (INTTSnOD).

To use the thinning out function for peak/trough interrupts, set the TSnID4 to TSnID0 bits.

## (f) Reload thinning out function setting

Reload timings can be set to the same timing as interrupt timings by setting the TSnRDE bit of the TSnOPT1 register to 1.

#### (g) A/D conversion trigger output setting

A/D conversion trigger 0 (TSnADTRG0 signal) can be set using the TSnAT07 to TSnAT00 bits of the TSnOPT2 register.

Enabling/disabling of A/D conversion trigger output upon a match with the TSnCCR5 register (16-bit counter count-up/down operation), a match with the TSnCCR4 register (16-bit counter count-up/down operation), at a peak interrupt (INTTSnCD0), or at a trough interrupt of the 16-bit counter or 16-bit sub-counter, is set with the TSnAT07 to TSnAT00 bits.

A/D conversion trigger 1 (TSnADTRG1 signal) can be set using the TSnAT17 to TSnAT10 bits of the TSnOPT3 register.

Enabling/disabling of A/D conversion trigger output upon a match with the



TSnCCR5 register (16-bit counter count-up/down operation), a match with TSnCCR4 register (16-bit counter count-up/down operation), at a peak interrupt (INTTSnCD0), or at a trough interrupt of the 16-bit counter or 16-bit sub-counter, is set with the TSnAT17 to TSnAT10 bits.

To set match timings for the TSnCCR4 and TSnCCR5 register, set the compare values to each register.

The thinning out function can be used for the TSnADTRG0 and TSnADTRG1 signals. No thinning out, 1-thinning out, 3-thinning out and 7-thinning out can be set with the TSnACC01 and TSnACC00 bits of the TSnOPT2 register, and the TSnACC11 and TSnACC10 bits of the TSnOPT3 register.

**Caution** Set the TSnOPT2, TSnOPT3, TSnCCR4, and TSnCCR5 registers correctly in order to output A/D conversion trigger timing pulse to the TOSn7 pin.

## (h) Dead time setting

A dead time is set with the TSnDTC0 and TSnDTC1 registers. A dead time can be calculated with the following expressions. 16-bit counter operation clock cycle  $\times$  TSnDTC0 16-bit counter operation clock cycle  $\times$  TSnDTC1

The time from inactive change of the TOSn2, TOSn4, and TOSn6 pins to active change of the TOSn1, TOSn3, and TOSn5 pins can be set with the TSnDTC0 register.

The time from inactive change of the TOSn1, TOSn3, and TOSn5 pins to active change of the TOSn2, TOSn4, and TOSn6 pins can be set with TSnDTC1 register.

## (i) Carrier wave cycle

Set the carrier wave cycle with the TSnCCR0 register based on the following expressions.

TSnCCR0 = (Carrier-wave cycle/16-bit counter operation clock cycle) + TSnDTC1 + TSnDTC0

The value set to the TSnCCR0 register must satisfy the following conditions in view of the dead time. TSnCCR0 >  $3 \times MAX$  (TSnDTC0, TSnDTC1) + MIN (TSnDTC0, TSnDTC1)  $0002H \leq TSnCCR0 \leq FFFEH$ 

TSnCCR0 must be an even number.

Note MAX (A, B) indicates the greater value of A and B, and MIN (A, B) indicates the smaller value of A and B.



## (j) Duty (PWM width) setting

U, V and W-phase duties can be set with the TSnCCR1 to TSnCCR3 registers, respectively. The setting range of the TSnCCR1 to TSnCCR3 registers are as follows.

 $0000H \le TSnCCR1$  to  $TSnCCR3 \le TSnCCR0 + 1$ 

LSB (Least Significant Bit) of the TSnCCR1 to TSnCCR3 registers means the additional pulse setting.

When TSnCCR1 = 0003H, a negative phase (TOSn2 pin) change delays by one count clock compared with that when TSnCCR1 = 0002H (during count-up operation by the 16-bit counter).

Caution Do not perform setting such that TSnCCR0 + 2 < TSnCCR1 to TSnCCR3.

## (3) 16-bit counter operation in high-accuracy T-PWM mode

The initial value of the 16-bit counter is FFFEH, the value "TSnDTC0 value + 2" is loaded immediately after the timer Sn operation is set to start (TSnCE of TSnCTL0 register = 1), and the 16-bit counter counts up in units of +2. Then, the 16-bit counter counts down in units of -2 at the match timing with "TSnCCR0 – TSnDTC1".

The 16-bit counter operates as follows.



Figure 17-76 16-Bit counter operation in high-accuracy T-PWM mode

Note 16-bit counter minimum value: TSnDTC0 16-bit counter maximum value: TSnCCR0 – TSnDTC1 Carrier-wave cycle: (TSnCCR0 – TSnDTC0 – TSnDTC1) × count clock cycle



The initial value of the 16-bit sub-counter is FFFEH, and the value "TSnDTC0 value -2" is loaded immediately after the timer Sn operation is set to start (TSnCE of TSnCTL0 register = 1). Then, the 16-bit counter counts down in units of -2 until the value matches with 0000H and starts counting up in units of +2 at the match timing.

The 16-bit counter value is loaded to the 16-bit sub-counter when the 16-bit counter operation is switched from counting up to counting down. The 16-bit sub-counter continues the count-up operation and starts counting down in units of -2 at the match timing with the TSnCCR0 register. The 16-bit counter value is loaded at the match timing with the TSnDTC0 register, and counting down is continued.

The 16-bit sub-counter operates as follows.



- Figure 17-77 16-Bit sub-counter operation in high-accuracy T-PWM mode
  - Note 16-bit sub-counter minimum value: 0000H 16-bit sub-counter maximum value: TSnCCR0



## (4) Basic operation in high-accuracy T-PWM mode

#### (a) Timer output example immediately after timer Sn operation starts

The timing diagram when TSnCCR0 = 0010H, TSnDTC0 = 0002H, TSnDTC1 = 0004H, and the TSnCCR1 register = 0000H to 0010H (partly extracted) is shown below. In this example, TSnOL1 to TSnOL6 of the TSnIOC0 register are set to 000000B.

When TSnCCR1 = TSnDTC0, the TOSn2 pin output level changes after compare match. In case of TSnCCR1  $\leq$  TSnDTC0 – 0002H, the TOSn2 pin output level varies to the active level when the initial value of the count is loaded after the timer Sn operation starts (TSnCE of TSnCTL0 register = 1). Change of the TOSn2 pin output level delays by one count clock compared with the case of TSnCCR1 = TSnDTC0 – 0002H, because TSnCCR1 = TSnDTC0 – 0001H is an additional pulse.



Figure 17-78 Timer output example when TSnCE = 1 (in high-accuracy T-PWM mode)

- Note 1. TSnCCR0 = 0010H, TSnDTC0 = 0002H, TSnDTC1 = 0004H
  - T<sub>D0</sub>:Time depending on TSnDTC0 register dead time setting T<sub>D1</sub>:Time depending on TSnDTC1 register dead time setting T<sub>S1</sub>:Time determined by result of compare between 16-bit sub-counter and TSnCCR1 when TSnCCR1 > 16-bit counter maximum value

RENESAS

#### (b) Timer output example during timer Sn operation

The timing diagram when TSnCCR0 = 0010H, TSnDTC0 = 0002H, TSnDTC1 = 0004H, and the TSnCCR1 register = 0000H to 0010H (partly extracted) is shown below. In this example, TSnOL1 to TSnOL6 of the TSnIOC0 register are set to 000000B.

The active (high level) range output by the positive phase (TOSn1 pin) is  $0000H \le TSnCCR1 < TSnCCR0 - TSnDTC1 - TSnDTC0$  (additional pulse). The active (high level) range output by the negative phase (TOSn0 pin) is TSnDTC0 + TSnDTC1 < TSnCCR1  $\le$  TSnCCR0.



Figure 17-79 Timer output example during operation (in high-accuracy T-PWM mode)

- Note 1. TSnCCR0 = 0010H, TSnDTC0 = 0002H, TSnDTC1 = 0004H
  - T<sub>D0</sub>:Time depends on TSnDTC0 register dead time setting T<sub>D1</sub>:Time depends on TSnDTC1 register dead time setting T<sub>S0</sub>:Time determined by compare between 16-bit sub-counter and TSnCCR1 when TSnCCR1 < 16-bit counter minimum value. T<sub>S1</sub>:Time determined by result of compare between 16-bit sub-counter and TSnCCR1 when TSnCCR1 > 16-bit counter maximum value.

RENESAS

#### (5) Additional pulse control in high-accuracy T-PWM mode

In the high-accuracy T-PWM mode, the additional pulse can be set by setting LSB of the duty setting registers (TSnCCR1 to TSnCCR3) to 1. The additional pulse control function enables finer duty control (with higher accuracy). The examples of the TOSn1 pin output with/without additional pulse control are shown below, with the setting of TSnCCR0 = 12, and TSnDTC0, TSnDTC1 = 0.

## (a) Pulse output with additional pulse control

In *Figure 17-80 on page 805*, additional pulse control is performed when an odd value is set to the TSnCCR1 register. Arrows and figures indicate the duty range of the TOSn1 pin output in one cycle.

As shown in *Figure 17-80 on page 805*, the TOSn1 pin output range (duty ratio) can be controlled by 1 count clock from 12-clock to 0-clock range when additional pulse control is performed.



Figure 17-80 TOSn1 pin output example with additional pulse control

Note TSnCCR0 = 12, TSnDTC0 = 0, TSnDTC1 = 0



# (b) Pulse output without additional pulse control

In *Figure 17-81 on page 806*, arrows and figures indicate the duty range of the TOSn1 pin output in one cycle.

The TOSn1 pin output range is controlled by 2 count clocks from 12-clock to 0clock range if additional pulse control is not performed. In this case, duty variation volume becomes larger than that when additional pulse control is performed.





Note TSnCCR0 = 12, TSnDTC0 = 0, TSnDTC1 = 0



# (6) Caution on timer output in high-accuracy T-PWM mode

There are cautions for TSnCCR1 to TSnCCR3 as follows when varying 6phase PWM duty by using reload (batch rewrite).

## (a) In case of TSnCCR0 + $2 \le$ TSnCCRm (Setting prohibited)

*Figure 17-82 on page 807* shows the case when the value of "TSnCCR0 + 2 or more" is set to the TSnCCR1 register. When the TSnCCR1 register setting is changed like this, a match between the 16-bit counter and TSnCCR1 register does not occur thereafter. Therefore, the TOSn1 pin output level is forcibly changed to inactive level at the following 16-bit sub-counter trough timing. Output will be switched at 16-bit sub-counter peak/trough timing after that.



Figure 17-82 Output when TSnCCR0 + 2 ≤ TSnCCR1

Note m = 1 to 3



## (b) In case of rewriting from TSnCCRm = 0000H to TSnCCRm = TSnCCR0

*Figure 17-83* shows the output waveform where the TSnCCR1 register setting is changed from 100% output to 0% output.

The TOSn1 pin output is inverted upon a match between the TSnCCR1 register and 16-bit sub-counter, and the TOSn2 pin output is inverted after the dead time count.



Figure 17-83 Output when rewriting from TSnCCR1 = 0000H to TSnCCR1 = TSnCCR0

### (c) In case of rewriting from "TSnDTC0 + TSnDTC1 < TSnCCRm < TSnCCR0 - TSnDTC0 - TSnDTC1" to "TSnCCRm < TSnDTC0 + TSnDTC1"

*Figure 17-84* shows the output waveform when rewriting the TSnCCR1 register from x (TSnDTC0 + TSnDTC1 < x < TSnCCR0 - TSnDTC0 - TSnDTC1) to y (y < TSnDTC0 + TSnDTC1).

In this case, the TOSn1 pin output becomes active when the TOSn1 pin set condition occurs upon a match between the 16-bit counter (or 16-bit subcounter) and the TSnCCR1 register immediately after reload (batch rewrite).



Figure 17-84 Output when rewriting from TSnDTC0 + TSnDTC1 < TSnCCR1 < TSnCCR0 - TSnDTC0 - TSnDTC1 to TSnCCR1 < TSnDTC0 + TSnDTC1

Note m = 1 to 3



# (d) In case of rewriting from "TSnDTC0 + TSnDTC1 < TSnCCRm < TSnCCR0 - TSnDTC0 - TSnDTC1" to "TSnCCR0 - TSnDTC1 + 1 < TSnCCRm < TSnCCR0"

*Figure 17-85* shows the output waveform when rewriting the TSnCCR1 register from x (TSnDTC0 + TSnDTC1 < x < TSnCCR0 - TSnDTC0 - TSnDTC1) to y (TSnCCR0 - TSnDTC0 - TSnDTC1 < TSnDTC0 < TSnCCR0). In this case, the TOSn2 pin output becomes inactive (high level) when the TOSn2 pin set condition occurs upon a match between the 16-bit counter (or 16-bit sub-counter) and TSnCCRm register immediately after batch rewrite.



Figure 17-85 Output when rewriting from "TSnDTC0 + TSnDTC1 < TSnCCR1 < TSnCCR0 - TSnDTC0 - TSnDTC1" to "TSnCCR0 - TSnDTC1 + 1 < TSnCCR1 < TSnCCR0"

Note m = 1 to 3



# (7) Timer output change after compare register updating

Timer output is affected when the compare register value is updated during reload execution. The timer output level is changed at any timing listed in *Table 17-33 on page 782* and *Table 17-34 on page 810*.

### Table 17-34 Positive phase operation condition list

| Operation | Symbol | Condition                                                                                                                                                                                                   |
|-----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Set       | ST1    | Match between counting up near the 16-bit sub-counter trough and compare register values                                                                                                                    |
| Clear     | RT1    | Match between counting down near the 16-bit sub-counter trough and compare register values                                                                                                                  |
| Set       | ST2    | At completion of dead time counter (TSnDTC0) operation                                                                                                                                                      |
| Clear     | RT2    | When 16-bit counter value matches with compare register value during count-down operation                                                                                                                   |
| Set       | ST3    | 100% output for PWM duty                                                                                                                                                                                    |
| Clear     | RT3    | When no match occurs until 16-bit sub-counter counts down to 0000H                                                                                                                                          |
| Clear     | RT4    | TSnCCR0 and TSnDTC0 settings are changed at a reload<br>timing.<br>Though neither a match (nor a match interrupt) occurs<br>between TSnCCR0 and TSnDTC0, the operation is cleared<br>by special processing. |
| Clear     | RT5    | The operation is cleared upon a match between peripheral 16-bit sub-counter peak and compare register values in positive phase active level.                                                                |

#### Table 17-35 Negative phase operation condition list

| Operation | Symbol | Condition                                                                                                                                                                                                   |
|-----------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Set       | SB1    | Match between counting down near the 16-bit sub-counter peak and compare register values                                                                                                                    |
| Clear     | RB1    | Match between counting up near the 16-bit sub-counter peak and compare register values                                                                                                                      |
| Set       | SB2    | At completion of dead time counter (TSnDTC1) operation                                                                                                                                                      |
| Clear     | RB2    | When 16-bit counter value matches with compare register value during count-up operation                                                                                                                     |
| Set       | SB3    | 100% output for PWM duty                                                                                                                                                                                    |
| Clear     | RB3    | When no match occurs until 16-bit sub-counter counts up to TSnCCR0                                                                                                                                          |
| Clear     | RB4    | TSnCCR0 and TSnDTC0 settings are changed at a reload<br>timing.<br>Though neither a match (nor a match interrupt) occurs<br>between TSnCCR0 and TSnDTC1, the operation is cleared<br>by special processing. |
| Clear     | RB5    | The operation is cleared upon a match between peripheral 16-bit sub-counter trough and compare register values in negative phase active level.                                                              |



| Compare register<br>value<br>immediately<br>before trough<br>reload | Compare register value after trough reload (TSnDTC0 < TSnDTC1)               | Figure No.                  |
|---------------------------------------------------------------------|------------------------------------------------------------------------------|-----------------------------|
| 0000H                                                               | 0000H < TSnCCR1 to TSnCCR3 < TSnDTC0                                         | Figure 17-86<br>on page 811 |
|                                                                     | TSnCCR1 to TSnCCR3 = 0000H, TSnDTC0 + 1                                      | Figure 17-87<br>on page 812 |
|                                                                     | TSnDTC0 + 1 < TSnCCR1 to TSnCCR3 $\leq$ TSnDTC0 $\times$ 2                   | Figure 17-88<br>on page 812 |
|                                                                     | TSnDTC0 × 2 < TSnCCR1 to<br>TSnCCR3 < TSnCCR0 – TSnDTC0 – TSnDTC1            | Figure 17-89<br>on page 813 |
|                                                                     | TSnCCR0 – TSnDTC0 – TSnDTC1 $\leq$ TSnCCR1 to<br>TSnCCR3 < TSnCCR0 – TSnDTC1 | Figure 17-90<br>on page 813 |
|                                                                     | $TSnCCR0 - TSnDTC1 \leq TSnCCR1 \text{ to } TSnCCR3 < TSnCCR0$               | Figure 17-91<br>on page 813 |
|                                                                     | TSnCCR1 to TSnCCR3 = TSnCCR0                                                 | Figure 17-92<br>on page 814 |



Figure 17-86 TSnCCR1 to TSnCCR3 = 0000H  $\rightarrow$  0000H < TSnCCR1 to TSnCCR3 < TSnDTC0





Figure 17-87 TSnCCR1 to TSnCCR3 = 0000H  $\rightarrow$  TSnCCR1 to TSnCCR3 = TSnDTC0, TSnDTC0 + 1



Figure 17-88 TSnCCR1 to TSnCCR3 = 0000H  $\rightarrow$  TSnDTC0 < TSnCCR1 to TSnCCR3 < TSnDTC0  $\times$  2

When the values of TSnCCR1 to TSnCCR3 are changed from "0000H  $\leq$  TSnCCR1 to TSnCCR3 < TSnDTC0" to "TSnDTC0 < TSnCCR1 to TSnCCR3 < TSnDTC0  $\times$  2", the positive phase will be 100% output for one cycle, as shown in *Figure 17-88*. To prevent this phenomenon, change "0000H  $\leq$  TSnCCR1 to TSnCCR3 < TSnDTC0" to "TSnDTC0 < TSnCCR1 to TSnCCR3 < TSnDTC  $\times$  2" through TSnDTC0, or directly change "0000H  $\leq$  TSnCCR1 to TSnCCR3 < TSnDTC0" to "TSnDTC0  $\times$  2  $\leq$  TSnCCR1 to TSnCCR3".









Figure 17-90 TSnCCR1 to TSnCCR3 = 0000H  $\rightarrow$  TSnCCR0 – TSnDTC1 – TSnDTC0 < TSnCCR1 to TSnCCR3 < TSnCCR0 – TSnDTC1



Figure 17-91 TSnCCR1 to TSnCCR3 = 0000H  $\rightarrow$  TSnCCR0 – TSnDTC1 < TSnCCR1 to TSnCCR3 < TSnCCR0





Figure 17-92 TSnCCR1 to TSnCCR3 = 0000H  $\rightarrow$  TSnCCR1 to TSnCCR3 < TSnCCR0



| Compare register<br>value immediately<br>before trough<br>reload | Compare register value after trough reload                                   | Figure No.                  |
|------------------------------------------------------------------|------------------------------------------------------------------------------|-----------------------------|
| TSnCCR0                                                          | TSnCCR1 to TSnCCR3 = 0000H                                                   | Figure 17-93 on page 815    |
|                                                                  | 0000H < TSnCCR1 to TSnCCR3 < TSnDTC0                                         | Figure 17-94 on<br>page 816 |
|                                                                  | TSnCCR1 to TSnCCR3 = TSnDTC0, TSnDTC0 + 1                                    | Figure 17-95 on page 816    |
|                                                                  | TSnDTC0 + 1 < TSnCCR1 to TSnCCR3 < TSnDTC0 + TSnDTC1                         | Figure 17-96 on page 817    |
|                                                                  | TSnDTC0 + TSnDTC1 < TSnCCR1 to<br>TSnCCR3 < TSnCCR0 – TSnDTC0 – TSnDTC1      | Figure 17-97 on page 817    |
|                                                                  | TSnCCR0 – TSnDTC0 – TSnDTC1 $\leq$ TSnCCR1 to<br>TSnCCR3 < TSnCCR0 – TSnDTC1 | Figure 17-98 on page 818    |
|                                                                  | $TSnCCR0 - TSnDTC1 \le TSnCCR1$ to $TSnCCR3 < TSnCCR0$                       | Figure 17-99 on page 818    |



Figure 17-93 TSnCCR1 to TSnCCR3 = TSnCCR0  $\rightarrow$  TSnCCR1 to TSnCCR3 = 0000H









Figure 17-95 TSnCCR1 to TSnCCR3 = TSnCCR0  $\rightarrow$  TSnCCR1 to TSnCCR3 = TSnDTC0, TSnDTC0 + 1





Figure 17-96 TSnCCR1 to TSnCCR3 = TSnCCR0  $\rightarrow$  TSnDTC0 + 1 < TSnCCR1 to TSnCCR3  $\leq$  TSnDTC0 + TSnDTC1



Figure 17-97 TSnCCR1 to TSnCCR3 = TSnCCR0  $\rightarrow$  TSnDTC0 + TSnDTC1 < TSnCCR1 to TSnCCR3 < TSnCCR0 - TSnDTC1 - TSnDTC0





Figure 17-98 TSnCCR1 to TSnCCR3 = TSnCCR0  $\rightarrow$  TSnCCR0 – TSnDTC1 – TSnDTC0 < TSnCCR1 to TSnCCR3 < TSnCCR0 – TSnDTC1



Figure 17-99 TSnCCR1 to TSnCCR3 = TSnCCR0  $\rightarrow$  TSnCCR0 – TSnDTC1  $\leq$  TSnCCR1 to TSnCCR3 < TSnCCR0



| Compare register<br>value immediately<br>before peak reload | Compare register value after peak reload<br>(TSnDTC1 < TSnDTC0)               | Figure No.                   |
|-------------------------------------------------------------|-------------------------------------------------------------------------------|------------------------------|
| TSnCCR0                                                     | TSnCCR0 – TSnDTC1 $\leq$ TSnCCR1 to TSnCCR3 < TSnCCR0                         | Figure 17-100<br>on page 819 |
|                                                             | TSnCCR1 to TSnCCR3 = TSnCCR0 – TSnDTC1                                        | Figure 17-101<br>on page 820 |
|                                                             | TSnCCR0 – TSnDTC1 $\times$ 2 $\leq$ TSnCCR1 to<br>TSnCCR3 < TSnCCR0 – TSnDTC1 | Figure 17-102<br>on page 820 |
|                                                             | TSnDTC0 + TSnDTC1 < TSnCCR1 to<br>TSnCCR3 < TSnCCR0 - TSnDTC1 × 2             | Figure 17-103<br>on page 821 |
|                                                             | TSnDTC0 + 1 < TSnCCR1 to TSnCCR3 < TSnDTC0 + TSnDTC1                          | Figure 17-104<br>on page 821 |
|                                                             | 0000H < TSnCCR1 to TSnCCR3 ≤ TSnDTC0 + 1                                      | Figure 17-105<br>on page 822 |
|                                                             | TSnCCR1 to TSnCCR3 = 0000H                                                    | Figure 17-106<br>on page 822 |



Figure 17-100 TSnCCR1 to TSnCCR3 = TSnCCR0  $\rightarrow$  TSnCCR0 - TSnDTC1 < TSnCCR1 to TSnCCR3 < TSnCCR0





Figure 17-101 TSnCCR1 to TSnCCR3 = TSnCCR0  $\rightarrow$  TSnCCR1 to TSnCCR3 = TSnDTC0 - TSnDTC1



Figure 17-102 TSnCCR1 to TSnCCR3 = TSnCCR0  $\rightarrow$  TSnCCR0 – TSnDTC1 x 2 < TSnCCR1 to TSnCCR3 < TSnCCR0 – TSnDTC1

When the values of TSnCCR1 to TSnCCR3 are changed from "TSnCCR0 – TSnDTC1 < TSnCCR1 to TSnCCR3  $\leq$  TSnCCR0" to "TSnCCR0 – TSnDTC1 × 2 < TSnCCR1 to TSnCCR3 < TSnCCR0 – TSnDTC1", the negative phase will be 100% output for one cycle, as shown in *Figure 17-102*. To prevent this phenomenon, change "TSnCCR0 – TSnDTC1 < TSnCCR1 to TSnCCR3  $\leq$  TSnCCR0" to "TSnDTC0 < TSnCCR1 to TSnCCR3 < TSnDT1 × 2" through "TSnCCR0 – TSnDTC1", o directly change "TSnCCR0 – TSnDTC1 < TSnDTC1 < TSnCCR1 to TSnCCR3 < TSnCCR0" to "TSnCCR0" to "TSnCCR1 to TSnCCR3  $\leq$  TSnCCR0 – TSnDTC1 × 2".





Figure 17-103 TSnCCR1 to TSnCCR3 = TSnCCR0  $\rightarrow$  TSnDTC0 + TSnDTC1 < TSnCCR1 to TSnCCR3 < TSnCCR0 – TSnDTC1 x 2



Figure 17-104 TSnCCR1 to TSnCCR3 = TSnCCR0  $\rightarrow$  TSnDTC0 + 1 < TSnCCR1 to TSnCCR3  $\leq$  TSnDTC0 + TSnDTC1





Figure 17-105 TSnCCR1 to TSnCCR3 = TSnCCR0  $\rightarrow$  0000H < TSnCCR1 to TSnCCR3  $\leq$  TSnDTC0 + 1



Figure 17-106 TSnCCR1 to TSnCCR3 = TSnCCR0  $\rightarrow$  TSnCCR1 to TSnCCR3 = 0000H



Figure 17-107 TSnCCR1 to TSnCCR3 = 0000H  $\rightarrow$  TSnCCR1 to TSnCCR3 = TSnCCR0



| Compare register<br>value immediately<br>before peak reload | Compare register value after trough reload                                                                              | Figure No.                   |
|-------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|------------------------------|
| 0000H                                                       | TSnCCR1 to TSnCCR3 = TSnCCR0                                                                                            | Figure 17-107<br>on page 822 |
|                                                             | TSnCCR0 – TSnDTC1 < TSnCCR1 to TSnCCR3 < TSnCCR0                                                                        | Figure 17-108<br>on page 823 |
|                                                             | TSnCCR1 to TSnCCR3 = TSnCCR0 – TSnDTC1                                                                                  | Figure 17-109<br>on page 824 |
|                                                             | $\label{eq:scalar} \begin{array}{l} TSnCCR0-TSnDTC0-TSnDTC1 \leq TSnCCR1 \ to \\ TSnCCR3 < TSnCCR0-TSnDTC1 \end{array}$ | Figure 17-110<br>on page 824 |
|                                                             | TSnDTC0 + TSnDTC1 < TSnCCR1 to<br>TSnCCR3 < TSnCCR0 – TSnDTC0 – TSnDTC1                                                 | Figure 17-111<br>on page 825 |
|                                                             | TSnDTC0 + 1 < TSnCCR1 to TSnCCR3 ≤ TSnDTC0 + TSnDTC1                                                                    | Figure 17-112<br>on page 825 |
|                                                             | 0000H < TSnCCR1 to TSnCCR3 ≤ TSnDTC0 + 1                                                                                | Figure 17-113<br>on page 825 |



Figure 17-108 TSnCCR1 to TSnCCR3 = 0000H  $\rightarrow$  TSnCCR0 - TSnDTC1 < TSnCCR1 to TSnCCR3 < TSnCCR0





Figure 17-109 TSnCCR1 to TSnCCR3 = 0000H  $\rightarrow$  TSnCCR1 to TSnCCR3 = TSnCCR0 - TSnDTC1



Figure 17-110 TSnCCR1 to TSnCCR3 = 0000H  $\rightarrow$  TSnCCR0 – TSnDTC0 – TSnDTC1 < TSnCCR1 to TSnCCR3 < TSnCCR0 – TSnDTC1





Figure 17-111 TSnCCR1 to TSnCCR3 = 0000H  $\rightarrow$  TSnDTC0 + TSnDTC1 < TSnCCR1 to TSnCCR3  $\leq$  TSnCCR0 - TSnDTC0 - TSnDTC1



Figure 17-112 TSnCCR1 to TSnCCR3 = 0000H  $\rightarrow$  TSnDTC0 + 1 < TSnCCR1 to TSnCCR3 < TSnDTC0 + TSnDTC1



Figure 17-113 TSnCCR1 to TSnCCR3 = 0000H  $\rightarrow$  0000H < TSnCCR1 to TSnCCR3  $\leq$  TSnDTC0 + 1

RENESAS

# (8) Dead time control in high-accuracy T-PWM mode

In the high-accuracy T-PWM mode, the TSnCCR1 to TSnCCR3 registers are used for duty setting and the TSnCCR0 register is used for cycle setting. By using these four registers, duty variable type 6-phase PWM waveform can be output. To implement dead time control, there are three 10-bit down-counters that synchronously operate with the count clock of the 16-bit counter, and two dead time setting registers (TSnDTC0, TSnDTC1).

The TSnDTC0 register is used to set the dead time from when a negative phase changes to inactive until a positive phase changes to active. The TSnDTC1 register is used to set the dead time from when a positive phase changes to inactive until a negative phase changes to active. The output waveform in case of TSnDTC0 = x, TSnDTC1 = y is shown below.



Figure 17-114 Output waveform example when dead time is set



#### (9) Cautions on dead time control in high-accuracy T-PWM mode

### (a) Rewriting of TSnDTC0 and TSnDTC1 registers

The setting of the dead time in the TSnDTC0, TSnDTC1 registers can be rewritten during operation. Note the following cautions when rewriting the dead time setting during operation.

- **Caution 1.** Rewrite the TSnDTC0 and TSnDTC1 registers when using the reload function (TSnCMS = 0).
  - 2. When the TSnDTC0 and TSnDTC1 registers are rewritten, carrier-wave cycles will be changed. In cases where carrier-wave cycles should not be changed, rewrite the TSnCCR0 register value at the same time as changing the TSnDTC0 and TSnDTC1 registers.
  - **3.** Rewriting is prohibited when TSnCMS = 1.
  - 4. In case of changing TSnCCR0 and TSnCCR1 at a 16-bit counter peak: Match interrupts (INTTSnCC1 to INTTSnCC5) will not occur immediately after reload execution if the values set in the TSnCCR1 to TSnCCR5 register matches with and TSnCCR0 – TSnDTC1 (the new maximum value of main counter) after updating.



5. In case of changing TS0DTC0 at a 16-bit counter trough: Match interrupts (INTTSnCC1 to INTTSnCC5) will not occur immediately after reload execution if the values set in the TSnCCR1 to TSnCCR5 register match with TS0DTC0 (the new minimum value of main counter) after updating.





### (10) Caution on rewriting cycles in high-accuracy T-PWM mode

In high-accuracy T-PWM mode, setting conditions for the TSnCCR0, TSnDTC0, and TSnDTC1 registers are as follows.

 $3 \times MAX$  (TSnDTC0, TSnDTC1) + MIN (TSnDTC0, TSnDTC1) < TSnCCR0 0002H < TSnCCR0  $\leq$  FFFEH

MAX (A, B) indicates the greater value of A and B, and MIN (A, B) indicates the smaller value of A and B.

*Figure 17-115 on page 828* shows an operation example when the setting range is exceeded.

This example shows the case where the TSnDTC0 register is set out of the range "TSnDTC0  $\geq$  TSnCCR0 – TSnDTC1". Though the 16-bit counter executes count-down operation, the count-down operation is executed from 0000H because no match occurs. In this case, the count operation continues by loading the TSnDTC0 register setting value. However, no match with TSnCCR0 – TSnDTC1 occurs in the count-up operation, thus the 16-bit counter overflows. In this case, the count operation continues by loading the TSnDTC0 register setting value. However, no match with TSnCCR0 – TSnDTC1 occurs in the count-up operation, thus the 16-bit counter overflows. In this case, the count operation continues by loading the TSnDTC0 register setting value again.

An overflow interrupt (INTTSnOV) occurs when the 16-bit counter loads the TSnDTC0 register setting value from 0000H or when an overflow occurs at FFFEH, and then the TSnOVF flag is set. An overflow interrupt (INTTSnOV) does not occur if the TSnCCR0, TSnDTC0, and TSnDTC1 registers are set correctly, so this can be used for detecting incorrect settings.



Figure 17-115 Operation example setting is out of range



## (11) Error interrupt (INTTSnER) in high-accuracy T-PWM mode

The positive/negative simultaneous active detection function can be used in the high-accuracy T-PWM mode. Error interrupts (INTTSnER) do not occur in the high-accuracy T-PWM mode. In case of occurrence, the internal circuits may be damaged.



Figure 17-116 Error interrupt operation example



#### (12) Software output control function in high-accuracy T-PWM mode

In the high-accuracy T-PWM mode, timer output control can be performed through software control by using the TSnSOC and TSnIPC2 to TSnIPC0 bits of the TSnOPT4 register, and the TSnIDC bit of the TSnOPT7 register. Output is switched immediately when TSnSOC is set to 1, as shown in *Figure 17-117 on page 830*. The dead time period is assured as long as the dead time is set. Output is retained until TSnSOC is cleared to 0. Then the function is switched to the output control by the high-accuracy T-PWM mode at the reload timing.

Refer to *"Software output function" on page 936* for details on the software output control function.



Figure 17-117 Software output control function switched from high-accuracy T-PWM mode

**Caution** Use the software output control function in the reload (batch rewrite) mode (TSnCMS of TSnOPT register = 0).



#### (a) Software output control procedure



Figure 17-118 Software output control function processing flow (1/2)

The procedure for software output control processing is as follows.

- <1> Set TSnIDC to determine the rotation direction. There is a 180° phase difference in the timer output between when TSnIDC = 0 and TSnIDC = 1. With the software output control function, the timer output is not changed only by rewriting of the bit.
- <2> Set the output pattern so as to output to TSnIPC2 to TSnIPC0 and also set TSnSOC to 1 to provide software output.
- <3> Change the output pattern setting of TSnIPC2 to TSnIPC0 to change the timer output. The settings of the following registers can be changed during software control. TSnCE bit of TSnCTL0 register, TSnOPT1 to TSnOPT4 registers, TSnIDC and TSnTOS bits of TSnOPT7 register, TSnCCR0 to TSnCCR5 registers, TSnDTC0 register, and TSnDTC1 register
- <4> Check that the reload request flag (TSnRSF) is 0. If TSnRSF = 1, do not proceed to the next step before TSnRSF is cleared to 0.

RENESAS

- <5> Software control release is started by clearing TSnSOC to 0 (Not yet released in this step).
- <6> Set the compare register required after the release of software output control. Proceed to the next step if changing is not needed. Change the register that has the reload function in this step, if necessary.
- <7> Write to the TSnCCR1 register to start reload.
- <8> Reload is executed and software output is released.
- Caution 1. Do not change TSnIPC2 to TSnIPC0 once after clearing TSnSOC to 0.
  - **2.** Be sure to execute reload after execution of procedures <4>, <5>, <6> and <7>. Software output cannot be released if reload cannot be executed.



#### (13) 180° excitation control in high-accuracy T-PWM mode

In the high-accuracy T-PWM mode, the 180° excitation control function can be used by using the TSnADC and TSnPOT bits of the TSnOPT5 register, the TSnIPC2 to TSnIPC0 bits of the TSnOPT4 register and the TSnIDC bit of the TSnOPT7 register.

Output is switched immediately when TSnADC is set to 1, as shown in *Figure 17-119 on page 833*. The dead time period is assured as long as the dead time is set. Then, when a trigger is input to the output pattern switch trigger (TSnSTCI1 and TSnSTCI0 signals or TAPTSn2 to TAPTSn0 pins), the output is changed in accordance with the setting of the TSnPSC bit of the TSnOPT4 register. Output is retained until TSnADC is cleared to 0. Then the function is switched to the output control by the high-accuracy T-PWM mode, at the reload timing.

Be sure to use the  $180^{\circ}$  excitation control function in reload (batch rewrite) mode (TSnCMS of TSnOPT0 register = 0).

Refer to *"180° excitation control function" on page 938* for details on 180° excitation control.



Figure 17-119 Example of switching 180° excitation control function in high-accuracy T-PWM mode







Figure 17-120 180° excitation control function processing flow



The procedure for 180° excitation control is as follows.

<1> TSnOPT7 register setting

Set a value to the TSnIDC bit to select the rotation direction. Set a value to the TSnPPC bit to select enable (1) or disable (0) of the pattern phase difference detection flag (TSnPPF) of input (TAPTSn2 to TAPTSn0 pins) or output (TSnOPF2 to TSnOPF0 flags) with the trigger switch method (TSnPOT of TSnOPT5 register = 1). Set a value to the TSnTDC bit to select enable (1) or disable (0) of the

TSnSTCI0, TSnSTCI1 signal simultaneous trigger detection flag (TSnTDF) with the trigger switch method.

Set values to the TSnPTC1 and TSnPTC0 bits to select enable (1) or disable (0) of the TAPTSn2 to TAPTSn0 pin abnormal toggle detection flag (TSnPTF).

<2> TSnOPT5 register setting

Set a value to the TSnPOT bit to select the pattern output trigger. The pattern switch method with which the output is switched with the input pattern of the TAPTSn2 to TAPTSn0 pins can be enabled by clearing TSnPOT to 0, and the trigger switch method with which the output is switched at a rising edge of the TSnSTCI0 and TSnSTCI1 signals can be enabled by setting TSnPOT to 1.

Set a value to the TSnPSS bit to select the pattern output order switch factor.

<3> TSnOPT4 register setting

Set a value to the TSnPSC bit to select the pattern output order for when TSnPSS of the TSnOPT5 register is 1 by using the trigger switch method. Set values to the TSnIPC2 to TSnIPC0 to select the initial pattern for the trigger switch method.

- <4> Start the 180° excitation control function by setting TSnADC to 1.
- <5> Output pattern switching

 Pattern switch method
 With the pattern switch method, the output is switched with the input pattern of TAPTSn2 to TAPTSn0 pins. However, the previous output level is held until [1, 1, 1]0 or [0, 0, 0] is input to the TAPTSn2 to TAPTSn0 pins.

- Trigger switch method
   With the trigger switch method, the output is switched at a rising edge of the TSnSTCI0 and TSnSTCI1 signals. Set the appropriate value to TSnIPC2 to TSnIPC0 to forcibly change the timer output.
   Writing to the TSnIPC2 to TSnIPC0 is prior to the rising edge of the TSnSTCI0 and TSnSTCI1 signals if both occur simultaneously.
- Switch method can be changed during operation.
- The registers that can be rewritten during 180° excitation control function operation are as follows.
   TSnCE bit of TSnCTL0 register, TSnOPT1 to TSnOPT5 registers, TSnOPT7 register, TSnCCR0 to TSnCCR5 registers, TSnDTC0 register, TSnDTC1 register
- **Caution** Setting TSnSOC of the TSnOPT4 register to 1 and TSnADC of TSnOPT5 register to 1 is prohibited.

Note <1> to <3> are in random order.



<6> Check that the reload request flag (TSnRSF) is 0. If TSnRSF = 1, do not proceed to the next step before TSnRSF is cleared to 0.
<7> Release of 180° excitation control is started by clearing TSnADC to 0 (Not yet released in this step). After TSnADC is changed to 0, output is switched at the switch timing of the pattern/trigger switch method until reload is executed. The output level can be changed forcibly by writing to TSnIPC2 to TSnIPC0.
<8> Set the compare register required after the release of 180° excitation control. Proceed to the next step if changing is not needed. Change the register that has the reload function in this step if necessary.
<9> Write to the TSnCCR1 register to start reload.
<10>Reload is executed and 180° excitation control is released.

**Caution** Be sure to execute reload after execution of steps <6>, <7>, <8> and <9>. 180° excitation control cannot be released if reload cannot be executed.



# (b) 180° excitation control switch timing from high-accuracy T-PWM mode

Output is switched immediately when switching from the high-accuracy T-PWM mode to 180° excitation control. Dead time control by hardware is inserted if the on-going output level is reversed. The output level is held until the reload is performed when switching from 180° excitation control to the high-accuracy T-PWM mode.



Figure 17-121 Output when switching between high-accuracy T-PWM Mode and 180° excitation control (in case of output reverse)



Figure 17-122 Output when switching between high-accuracy T-PWM Mode and 180° excitation control (in case of output not reversed)



The output switched during the dead time count is set without waiting for the dead time count to finish in case of the same phase, or is set after the dead time count finishes in case of the negative phase.



Figure 17-123 Output when switching between high-accuracy T-PWM mode and 180° excitation control (during dead time count)



#### (14) Semi-automatic driving system using high-accuracy T-PWM mode

This section explains the system in which the semi-automatic driving function is used in the high-accuracy T-PWM mode. *Figure 17-124 on page 839* shows the timing. The 180° excitation control function is automatically enabled by setting TSnADC of the TSnOPT5 register to 1. As shown here, the output pattern is switched by the TSnSTCI0 signal as a trigger in the 180° excitation control function, and the dead time set with the TSnDTC0 and TSnDTC1 registers is always added when switching.

Output is switched immediately when switching from the high-accuracy T-PWM mode to 180° excitation control, but control is switched after waiting for the reload timing when switching from 180° excitation control to the high-accuracy T-PWM mode.



Figure 17-124 Output example of semi-automatic driving system using high-accuracy T-PWM mode

Note Setting example TSnCTL1 register: TSnMD3 to 0 = [1, 0, 0, 0], TSnIOC0 register: TSnOE6 to 1 = [1, 1, 1, 1, 1, 1, 1], TSnOL6 to 1 = [0, 0, 0, 0, 0, 0], TSnOPT4 register: TSnIPC2 to 0 = [0, 0, 1], TSnPSC = 0, TSnOPT5 register: TSnADC = 1



## 17.10.9 PWM mode with dead time

#### (1) Overview of PWM mode with dead time

In the PWM mode with dead time, 6-phase PWM is generated to output from the TOSn1 to OSn6 pins by using the saw-tooth wave operation of the 16-bit counter and four 16-bit compare registers. The maximum value of the 16-bit counter is set with the TSnCCR0 register. The duty of the U, V, and W-phase voltage data signal is set with the TSnCCR1 to TSnCCR3 registers. Dead time is set with the TSnDTC0 and TSnDTC1 registers. The dead time from the negative phase to the positive phase and the dead time from the positive phase to the negative phase can be set with TSnDTC0 and TSnDTC1, respectively. The 16-bit counter counts up by setting 0000H as the minimum value. When matching with the maximum value (cycle), the 16-bit counter is cleared (0000H), and continues counting up.

The 10-bit dead time counter (TSnDTT1 to TSnDTT3) reloads the setting value of the TSnDTC0 and TSnDTC1 registers upon a match between the values of the 16-bit counter and the TSnCCR1 to TSnCCR3 registers to count down. Compare match interrupts (INTTSnCC0 to INTTSnCC3) occur upon respective match between the values of the 16-bit counter and TSnCCR0 to TSnCCR3 registers.

**Note** PWM mode with dead time is valid when TSnMD3 to TSnMD0 of the TSnCTL1 register are set to [1, 0, 0, 1].



Figure 17-125 Block diagram in PWM mode with dead time





- Figure 17-126 Basic operation flow in PWM mode with dead time
  - **Note** The 16-bit counter is not cleared upon a match between the values of the 16-bit counter and the TSnCCR1 to TSnCCR5 buffer registers.



## (2) PWM Mode with Dead Time Operation List

## (a) Register rewriting

| Register              | Rewriting method | Rewriting during operation             | Function                                              |
|-----------------------|------------------|----------------------------------------|-------------------------------------------------------|
| TSnCCR0               | Reload           | Possible                               | Cycle                                                 |
| TSnCCR1 to<br>TSnCCR3 | Reload           | Possible                               | PWM duty                                              |
| TSnCCR4,<br>TSnCCR5   | Reload           | Possible                               | PWM duty<br>(Selectable as A/D<br>conversion trigger) |
| TSnDTC0,<br>TSnDTC1   | Reload           | Conditionally possible <sup>Note</sup> | Cycle, dead time                                      |

**Note** Refer to *"Rewriting of TSnDTC0 and TSnDTC1 registers" on page 827* for details.

## (b) Input pin

| Pin    | Function |
|--------|----------|
| TTRGSn | -        |
| TEVTSn | -        |

## (c) Output pin

| Pin   | Function                                             |
|-------|------------------------------------------------------|
| TOSn0 | Toggle output by TSnCCR0 compare match               |
| TOSn1 | PWM output (with dead time) by TSnCCR1 compare match |
| TOSn2 | Negative phase output (with dead time) to TOSn1      |
| TOSn3 | PWM output (with dead time) by TSnCCR2 compare match |
| TOSn4 | Negative phase output (with dead time) to TOSn3      |
| TOSn5 | PWM output (with dead time) by TSnCCR3 compare match |
| TOSn6 | Negative phase output (with dead time) to TOSn5      |
| TOSn7 | Pulse output by A/D conversion trigger               |

## (d) Interrupt

| Interrupt                 | Function                                                  |
|---------------------------|-----------------------------------------------------------|
| INTTSnCC0 to<br>INTTSnCC5 | Compare match of TSnCCR0 to TSnCCR5 registers             |
| INTTSnOV                  | -                                                         |
| INTTSnER                  | Error                                                     |
| INTTSnOD                  | -                                                         |
| INTTSnCD0                 | Peak interrupt (occurs at the same timing with INTTSnCC0) |
| INTTSnWN                  | -                                                         |



#### (e) Compare match timing

| Compare match         | Timing                                                                 |
|-----------------------|------------------------------------------------------------------------|
| TSnCCR0               | When 16-bit counter switches from TSnCCR0 to 0000H                     |
| TSnCCR1 to<br>TSnCCR5 | After detection of match between 16-bit counter and TSnCCR1 to TSnCCR5 |

#### (f) Output condition

| Output           | Condition                       |
|------------------|---------------------------------|
| Duty 0% output   | TSnCCRm = 0000H                 |
| Duty 100% output | TSnCCR0 + TSnDTC0 + 1 = TSnCCRm |
| Dead time check  | TSnDTC0, TSnDTC1                |

#### Note 1. "-" indicates an unused function in the PWM mode with dead time.

**2.** m = 1 to 3, n = 0,1



Figure 17-127 Output waveform example in PWM mode with dead time

**Caution** 1. The maximum value settable to the TSnCCR1 to TSnCCR3 registers is "TSnCCR0 + TSnDTC0 + 1".

2. PWM output is provided with duty 0% when 0000H is set to the TSnCCR1 to TSnCCR3 registers.



- PWM output is provided with duty 100% when "TSnCCR0 + TSnDTC0 + 1" is set to the TSnCCR1 to TSnCCR3 registers.
- 4. Set the TSnCCR0 register to satisfy the condition "TSnDTC0 + TSnDTC1 < TSnCCR0  $\leq$  FFFFH TSnDTC0".

#### (3) Setting of PWM mode with dead time

#### (a) Mode setting

The PWM mode with dead time is set by setting TSnMD4 to TSnMD0 of the TSnCTL1 register to [1, 0, 0, 1].

#### (b) Output level/output enable setting

Output level/output enable is set by setting the TSnOL0 to TSnOL7 and TSnOE0 to TSnOE7 bits of the TSnIOC0 register.

Toggle output is provided from the TOSn0 pin upon the cycle match (match between the 16-bit counter and TSnCCR0 register).

Pulse output by A/D conversion trigger is provided from the TOSn7 pin. Set this pin as needed.

#### (c) Error interrupt occurrence enabling

Error interrupt (INTTSnER) occurrence is enabled by setting the TSnEOC bit of the TSnIOC4 register to 1 when the simultaneous positive/negative phase state is detected.

A pin that detects simultaneous active state is set by setting the TSnTBA2 to TSnTBA0 bits of the TSnIOC4 register. In the PWM mode with dead time, positive and negative phases do not become active even if any value is set to the TSnCCR0 to TSnCCR3 registers.

#### (d) Interrupt and thinning out function setting

A peak interrupt (INTTSnCD0) occurs upon a match between the TSnCCR0 register and 16-bit counter. (Trough interrupts do not occur). Set TSnICE of the TSnOPT1 register to 1 to output peak interrupts. To use the thinning out function for peak interrupt, execute setting with the TSnID4 to TSnID0 bits of the TSnOPT1 register.

#### (e) Reload thinning out function setting

Set TSnRDE of the TSnOPT2 register to 1 to set reload timing to the same timing as interrupt timing. Reload is performed when TSnRTE of the TSnOPT1 register is set to 1.



#### (f) A/D conversion trigger output setting

A/D conversion trigger 0 (TSnADTRG0 signal) is set by setting the TSnAT04, TSnAT02, TSnAT01 bits of the TSnOPT2 register. The TSnAT04, TSnAT02, and TSnAT01 bits specify whether to enable/disable A/D conversion trigger output upon match with the TSnCCR5 register, upon match with the TSnCCR4 register, and at the peak interrupt (INTTSnCD0) of the 16-bit counter or 16-bit sub-counter.

A/D conversion trigger 1 (TSnADTRG1 signal) is set by setting the TSnAT14, TSnAT12, and TSnAT11 bits of the TSnOPT3 register. The TSnAT14, TSnAT12, and TSnAT11 bits specify whether to enable/disable A/D conversion trigger output upon match with the TSnCCR5 register, upon match with the TSnCCR4 register, and at the peak interrupt (INTTSnCD0) of the 16-bit counter or 16-bit sub-counter.

Compare values are set with the TSnCCR4 and TSnCCR5 registers. Thinning out function is enabled for the TSnADTRG0 and TSnADTRG1 signals.

No thinning out, 1-thinning out, 3-thinning out and 7-thinning out setting can be executed with the TSnACC01 and TSnACC00 bits of the TSnOPT2 register, and the TSnACC11 and TSnACC10 bits of the TSnOPT3 register.

- **Caution** 1. Setting TSnAT07, TSnAT06, TSnAT05, TSnAT03, TSnAT00 of the TSnOPT2 register to 1 is prohibited.
  - **2.** Setting TSnAT17, TSnAT16, TSnAT15, TSnAT13, TSnAT10 of the TSnOPT3 register to 1 is prohibited.

#### (g) Dead time setting

Dead time is set with the TSnDTC0 and TSnDTC1 registers. Dead time can be calculated with the following equation. 16-bit counter operation clock cycle  $\times$  TSnDTC0 16-bit counter operation clock cycle  $\times$  TSnDTC1

The time for the change from the inactive state of the TOSn2, TOSn4, and TOSn6 pins to the active state of the TOSn1, TOSn3, and TOSn5 pins can be set with the TSnDTC0 register.

The time for the change from the inactive state of the TOSn1, TOSn3, and TOSn5 pins to the active state of the TOSn2, TOSn4, and TOSn6 pins can be set with the TSnDTC1 register.

#### (h) Duty (PWM width) setting

U, V and W-phase duties are set with the TSnCCR1 to TSnCCR3 registers respectively. The setting range of the TSnCCR1 to TSnCCR3 registers is as follows.

 $0000H \leq TSnCCR1 - TSnCCR3 \leq TSnCCR0 + TSnDTC0 + 1$ 

Set the TSnCCR0 register to satisfy the condition "TSnDTC0 + TSnDTC1 < TSnCCR0  $\leq$  FFFFH – TSnDTC0".



#### (4) Operation in PWM mode with dead time

*Figure 17-128 on page 846* shows the timing when setting TSnCCR0 = 0007H, TSnDTC0 = 0002H, TSnDTC1 = 0002H, and setting the TSnCCR0 register to 0000H to 0007H (in part).

The PWM width increases/decreases by 1 count clock if the compare value of the TSnCCR1 register increases/decreases. Arrows indicate the

increase/decrease by the TSnDTC1 + 1 count clock in *Figure 17-128 on page 846*.

This occurs when the value is rewritten to "TSnCCR1 + 0001H" which will be "TSnDTC1 < TSnCCR1" because the dead time control is valid.



- Figure 17-128 Timer output example in case of setting TSnCE = 1 (initial setting in PWM mode with dead time)
  - <1> PWM width without dead time
  - <2> PWM width decreases by TSnDTC1 + 1 because the PWM width with dead time is "TSnCCR1 = TSnDTC0 + 0001H".

RENESAS

## (5) Dead time control in PWM mode with dead time

In the PWM mode with dead time, the duty setting registers are TSnCCR1 to TSnCCR3, and the cycle setting register is TSnCCR0.

Duty variable type 6-phase PWM waveform output is provided by using these four registers.

There are three 10-bit down-counters that synchronously operate with the count clock of the 16-bit counter, and dead time setting registers (TSnDTC0, TSnDTC1) in order to achieve dead time control. Dead time from the negative phase changes to inactive until the positive phase changes to active is set by the TSnDTC0 register, and the dead time from the positive phase changes to inactive until the negative phase changes to active is set by the TSnDTC1 register.

Then, the output waveform in case of TSnDTC0 = x, TSnDTC1 = y is shown in *Figure 17-129 on page 847*.



Figure 17-129 Output waveform example in PWM mode with dead time



#### (6) Error interrupt (INTTSnER) in T-PWM mode with dead time

The positive/negative phase simultaneous active state detection function is enabled in the T-PWM mode with dead time. Error interrupts (INTTSnER) do not occur in the high-accuracy T-PWM mode. In case of occurrence, the internal circuit may be damaged.



Figure 17-130 Error interrupt operation example

## (7) Caution about interrupt timing in T-PWM mode with dead time

The interrupt output timing differs between "NTTSnCC0, INTTSnCC4, INTTSnCC5" and "INTTSnCC1, INTTSnCC2, INTTSnCC3". Therefore, interrupt timing will not be the same even if the same value is set.

| Operation clock                   |                          |
|-----------------------------------|--------------------------|
| Count clock                       |                          |
| 16-bit counter                    | 0004 0005 0000 0001 0002 |
| TSnCCR0 to TSnCCR5                | 0005                     |
| INTTSnCC1 to<br>INTTSnCC3         | Γ                        |
| INTTSnCC0, INTTSnCC4<br>INTTSnCC5 |                          |

Figure 17-131 Interrupt timing example in T-PWM mode with dead time



#### (8) Software output control function in PWM mode with dead time

Timer output control can be executed with software control by using the TSnSOC and TSnIPC2 to TSnIPC0 bits of the TSnOPT4 register, and the TSnIDC bit of the TSnOPT7 register.

Output is switched immediately at the time of setting TSnSOC = 1 as shown in *Figure 17-132*. Dead time period is assured by setting the dead time. Output is held at the time of setting TSnSOC = 0. Then the function is switched to the output control in the PWM mode with dead time at reload timing occurrence.

Refer to *"Software output function" on page 936* for details on the software output control function.



Figure 17-132 Software output control function switch example from PWM mode with dead time



#### (a) Software output control procedure



Figure 17-133 Processing flow in software output control

The software output control processing procedure is described below.

- <1> Set TSnIDC in order to determine rotation direction. There is a 180° phase difference in the timer output between when TSnIDC = 0 and TSnIDC = 1. In the software output control function, the timer output is not changed only by rewriting the bit.
- <2> Set the pattern to be output to TSnIPC2 toTSnIPC0 and also set TSnSOC to 1 in order to provide software output.
- <3> Change the output pattern setting of TSnIPC2 to TSnIPC0 to change the timer output.

The registers that can be changed during the software control are as follows.

TSnCE bit of the TSnCTL0 register, TSnOPT1 to TSnOPT4 registers, TSnIDC, TSnTOS bits of TSnOPT7 register, TSnCCR0 to TSnCCR5 registers, TSnDTC0 register, TSnDTC1 register

<4> Check that the reload request flag (TSnRSF) is set to 0. In the case of TSnRSF = 1, do not move to the next procedure until the setting of TSnRSF = 0.

RENESAS

- <5> Software control release is started by setting TSnSOC = 0 (Not yet released in this step).
- <6> Set the compare register which is necessary after the release of software output control. Move to the next procedure when any change is not needed. Change the register with the reload function in this step if necessary.
- <7> Write to the TSnCCR1 register to activate reload.
- <8> Execute reload to release the software output.
- Caution 1. Any change of TSnIPC2 to TSnIPC0 is prohibited after setting TSnSOC to 0.
  - 2. Be sure to execute reloading after the execution of procedures <4>, <5>, <6> and <7>. Software output cannot be released if reload cannot be executed.



## 17.10.10 120° excitation mode

#### (1) Overview of $120^{\circ}$ excitation mode

In the 120° excitation mode, 120° excitation control is performed by detecting the detection of external input (pattern: TAPTSn2 to TAPTSn0 pins, trigger: TSnSTCI0 signal) and by the output control of timer output (pins TOSn1 to TOSn6).

Motor systems that can be controlled in the  $120^\circ$  excitation mode are as follows.

- System where a hall sensor is connected at  $120^\circ$  intervals against the motor rotation
- System where normal/reverse rotation is possible by outputting, responding to the hall sensor input

A concrete output example of normal/reverse rotation is shown in *Figure 17-134 on page 852*.



- Figure 17-134 Normal/Reverse rotation example
  - Note 1. TSnOPT4 register: TSnSOC = 0, TSnOPT5 register: TSnADC, TSnPOT = 0
    - 2. The 120° excitation mode is valid when TSnMD3 to TSnMD0 of the TSnCTL1 register are set to [1, 0, 1, 0].







| Output Pin | TAPTSn2 to TAPTSn0 |           |           |           |           |           |           |           |
|------------|--------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
|            | [1, 0, 1]          | [1, 0, 0] | [1, 1, 0] | [0, 1, 0] | [0, 1, 1] | [0, 0, 1] | [0, 0, 0] | [1, 1, 1] |
| TOSn1      | PWM1               | PWM2      | INACT     | INACT     | INACT     | INACT     | Note 1    | Note 1    |
| TOSn2      | INACT              | INACT     | INACT     | PWM3      | PWM4      | INACT     | Note 1    | Note 1    |
| TOSn3      | INACT              | INACT     | PWM1      | PWM2      | INACT     | INACT     | Note 1    | Note 1    |
| TOSn4      | PWM4               | INACT     | INACT     | INACT     | INACT     | PWM3      | Note 1    | Note 1    |
| TOSn5      | INACT              | INACT     | INACT     | INACT     | PWM1      | PWM2      | Note 1    | Note 1    |
| TOSn6      | INACT              | PWM3      | PWM4      | INACT     | INACT     | INACT     | Note 1    | Note 1    |

Table 17-36 Output patten of TAPTSn2 to TAPTSn0 pins (normal rotation)

- **Note** 1. The output level of the TOSn0 to TOSn6 pins remains the level before change when changed to [0, 0, 0] or [1, 1, 1].
  - PWM1 to PWM4 indicate the PWM output of the TSnCCR1 to TSnCCR4 registers.
  - 3. NACT indicates the inactive level output.

There are the following two methods according to the external input used in the  $120^{\circ}$  excitation mode.

- Patten switch method: 3 patterns of input (hall sensor, etc.)
- Trigger input switch method: Trigger input (encoder circuit, offset, etc.)

## (a) Pattern switch method (TSnPOT of TSnOPT5 register = 0)

Level detection is performed for the TAPTSn2 to TAPTSn0 pins (three patterns of input from hall sensor) to decode the signals after the level detection. PWM output (which is to be determined with the values of the TSnCCR1 to TSnCCR4 registers) of the TOSn1 to TOSn6 pins is selected by judging the decode result. PWM output is generated by decoded signals and compare match interrupts (INTTSnCC1 to INTTSnCC4) to control the output. Dead time control is performed by the operation of the dead time counter at respective phase signal fall timing to ensure dead time insertion.

With the pattern switch method, the decoded pattern is output by using the data from input pattern (TAPTSn2 to TAPTSn0 pins), current direction control bit (TSnIDC of the TSnOPT7 register), TAPTSn2 to TAPTSn0 order detection flag (TSnTSF of the TSnOPT5 register). *Figure 17-136 on page 854* and *Figure 17-137 on page 855* show the timer output when the TAPTSn2 to TAPTSn0 pins are changed. The output pattern is switched to the pattern corresponding to the input jattern 1 to the input pattern 4.

The pattern set with the input level of the TAPTSn2 to TAPTSn0 pins, the TSnIDC and TSnARD signals, (TSnPSS of TSnOPT5 register = 0), and the TSnPSC bit of the TSnOPT4 register (TSnPSS of TSnOPT5 register = 1) is output. Output pattern is determined with the TSnTSF flag instead of the TSnPSC bit if the value of the TSnTSF flag is determined.

TSnOPT4 register: TSnSOC = 0, TSnPSC = 0, TSnOPT5 register: TSnPOT = 0, and TSnOPT7 register: TSnIDC = 0.



Figure 17-136 120° excitation mode operation example in use of pattern switch method (normal rotation)



## TSnOPT4 register: TSnSOC = 0, TSnPSC = 1, TSnOPT5 register: TSnPOT = 0, and TSnOPT7 register: TSnIDC = 1.







#### (b) Trigger switch method

With the trigger input switch method, rises of the TSnSTCI0 and TSnSTCI1 signals are detected to generate the output switch timing.

The timer output initial pattern is set with the TSnIPC2 to TSnIPC0 bits of the TSnOPT4 register. The output patterns after the initial pattern are determined with the TSnIPC2 to TSnIPC0 bits, rotation direction or the TSnIDC bit of the TSnOPT7 register. There are four patterns which can be output in combination of rotation direction and the TSnIDC bit.

| TSnOPT5 register |        | Rotation direction                                           |  |
|------------------|--------|--------------------------------------------------------------|--|
| TSnPOT           | TSnPSS |                                                              |  |
| 1                | 0      | Determine rotation direction by using input signal to TSnARD |  |
|                  | 1      | Determine rotation direction by using TSnPSC bit             |  |

TSnOPT4 register: TSnSOC = 0, TSnPSC = 0, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 0



Figure 17-138 120° excitation mode operation example in use of trigger input switch method (normal rotation)



TSnOPT4 register: TSnSOC = 0, TSnPSC = 1, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 1



Figure 17-139 120° excitation mode operation example in use of trigger input switch method (reverse rotation)





- Figure 17-140 Basic operation flow in 120° excitation mode
  - **Note** The 16-bit counter is not cleared upon a match between the values of the 16-bit counter and the TSnCCR1 to TSnCCR5 buffer registers.



#### (2) $120^{\circ}$ excitation mode operation list

## (a) Register rewriting

| Register              | Rewriting method | Rewriting During<br>Operation          | Function                                              |
|-----------------------|------------------|----------------------------------------|-------------------------------------------------------|
| TSnCCR0               | Reload           | Possible                               | Cycle                                                 |
| TSnCCR1 to<br>TSnCCR3 | Reload           | Possible                               | PWM duty                                              |
| TSnCCR4               | Reload           | Possible                               | PWM duty<br>(selectable as A/D<br>conversion trigger) |
| TSnCCR5               | Reload           | Possible                               | Selectable as A/D conversion trigger                  |
| TSnDTC0,<br>TSnDTC1   | Reload           | Conditionally possible <sup>Note</sup> | Dead time                                             |

**Note** Refer to *"Rewriting of TSnDTC0 and TSnDTC1 registers" on page 827* for details.

## (b) Input pin

| Pin                           | Function                   |
|-------------------------------|----------------------------|
| TTRGSn                        | -                          |
| TEVTSn                        | -                          |
| TAPTSn2 to TAPTSn0            | Pattern input              |
| TSnSTCI0, TSnSTCI1<br>signals | Trigger input              |
| TSnARD signal                 | Pattern change order input |

## (c) Output pin

| Pin   | Function                                                      |
|-------|---------------------------------------------------------------|
| TOSn0 | Toggle output by TSnCCR0 compare match                        |
| TOSn1 | PWM output (with dead time) by TSnCCR1, TSnCCR2 compare match |
| TOSn2 | PWM output (with dead time) by TSnCCR3, TSnCCR4 compare match |
| TOSn3 | PWM output (with dead time) by TSnCCR1, TSnCCR2 compare match |
| TOSn4 | PWM output (with dead time) by TSnCCR3, TSnCCR4 compare match |
| TOSn5 | PWM output (with dead time) by TSnCCR1, TSnCCR2 compare match |
| TOSn6 | PWM output (with dead time) by TSnCCR3, TSnCCR4 compare match |
| TOSn7 | Pulse output by A/D conversion trigger                        |



## (d) Interrupt

| Interrupt                 | Function                                                   |
|---------------------------|------------------------------------------------------------|
| INTTSnCC0 to<br>INTTSnCC5 | Compare match of INTTSnCC0 to INTTSnCC5 registers          |
| INTTSnOV                  | -                                                          |
| INTTSnER                  | Error                                                      |
| INTTSnOD                  | -                                                          |
| INTTSnCD0                 | Peak interrupt (occurs at the same timing with INTTSnCC0). |
| INTTSnWN                  | Warning                                                    |

## (e) Compare match timing

| Compare match         | Timing                                                                           |
|-----------------------|----------------------------------------------------------------------------------|
| TSnCCR0               | When 16-bit counter switches from TSnCCR0 to 0000H                               |
| TSnCCR1 to<br>TSnCCR5 | After detection of match between values of 16-bit counter and TSnCCR1 to TSnCCR5 |

Note "-" indicates an unused function in the 120° excitation mode.



#### (3) Setting of 120° excitation mode

#### (a) Mode setting

The  $120^{\circ}$  excitation mode is set by setting TSnMD3 to TSnMD0 of the TSnCTL1 register to [1, 0, 1, 0].

#### (b) Output level/output enable setting

Output level/output enable is set by setting the TSnOL0 to TSnOL7 and TSnOE0 to TSnOE7 bits of the TSnIOC0 register.

Toggle output is provided from the TOSn0 pin with cycle match (match between the 16-bit counter and TSnCCR0 register).

The TOSn7 pin is for A/D conversion output. Enable the output according to the need.

#### (c) Error interrupt/warning interrupt occurrence enabling

Error interrupt (INTTSnER) occurrence is enabled by setting the TSnEOC bit of the TSnIOC4 register to 1 when the positive/negative phase simultaneous active state is detected.

A warning interrupt (INTTSnWN) is enabled by setting TSnWOC of the TSnIOC4 register to 1.

#### (d) Interrupt and thinning out function setting

A peak interrupt (INTTSnCD0) occurs upon a match between the TSnCCR0 register and 16-bit counter. (A trough interrupt does not occur). Set TSnICE of the TSnOPT1 register to 1 to output a peak interrupt. To use the thinning out function for peak interrupt, set the TSnID4 to TSnID0 bits of the TSnOPT1 register.

#### (e) Reload thinning out function setting

Set TSnRDE of the TSnOPT1 register to 1 to set reload timing to the same timing with the interrupt timing.

#### (f) A/D conversion trigger output setting

To set A/D conversion trigger 0 (TSnADTRG0 signal), set whether to enable/disable at the match timing with the TSnCCR5 register, at the match timing with the TSnCCR4 register, and at the peak interrupt (INTTSnCD0) by using the TSnAT04, TSnAT02, and TSnAT01 bits of the TSnOPT2 register. To set A/D conversion trigger 1 (TSnADTRG1 signal), set whether to enable/disable at match timing with TSnCCR5 register, at match timing with the TSnCCR4 register, and at peak interrupt (INTTSnCD0) by using the TSnAT14, TSnAT12, and TSnAT11 bits of the TSnOPT3 register. No thinning out, 1-thinning out, 3-thinning out, or 7-thinning out can be set with the TSnACC01 and TSnACC00 bits of the TSnOPT3 register, and the TSnACC11 and TSnACC10 bits of the TSnOPT3 register.



- **Caution 1.** When using the TOSn7 pin, set the TSnOPT2 and TSnOPT3 registers and TSnCCR4 and TSnCCR5 registers appropriately according to the system.
  - Trough interrupts (INTTSnOD) do not occur in the 120° excitation mode. Be sure to set TSnAT00, 10 bits of the TSnOPT2 and TSnOPT3 registers to 0.
  - 3. The 16-bit sub-counter does not operate in the 120° excitation mode. Be sure to set the TSnAT07, TSnAT06, TSnAT17, and TSnAT16 bits of the TSnOPT2, TSnOPT3 registers to 0.
  - 4. The 16-bit counter does not enter the count-down status in the 120° excitation mode. Be sure to set the TSnAT05, TSnAT03, TSnAT15, and TSnAT13 bits of the TSnOPT2 and TSnOPT3 registers to 0.
  - 5. Both PWM duty and A/D0 conversion trigger are set with the TSnCCR4 register in the 120° excitation mode. Note that both the PWM duty and A/D0 conversion trigger timing will be changed if the TSnCCR4 register setting value is changed.

#### (g) Dead time setting

Dead time is set with the TSnDTC0 and TSnDTC1 registers. Dead time can be calculated with the following equation. 16-bit counter operation clock cycle  $\times$  TSnDTC0 16-bit counter operation clock cycle  $\times$  TSnDTC1

The time for the change from the inactive state of TOSn2, TOSn4, TOSn6 pins to the active state of TOSn1, TOSn3, TOSn5 pins can be set with the TSnDTC0 register.

The time for the change from the inactive state of TOSn1, TOSn3, TOSn5 pins to the active state of TOSn2, TOSn4, TOSn6 pins can be set with the TSnDTC1 register.

#### (h) Output PWM setting

In the 120° control, the output of the TOSn1, TOSn3, and TOSn5 pins is controlled with the TSnCCR1 and TSnCCR2 registers, and the output the TOSn2, TOSn4, and TOSn6 pins is controlled with the TSnCCR3 and TSnCCR4 registers. The duty ratio can be set with the TSnCCR1 to TSnCCR4 registers for the PWM cycle (TSnCCR0 register). 0000H must be set to the TSnCCR1 to TSnCCR4 registers to set the duty ratio of 0%, and "TSnCCR0 + 1" should be set to the TSnCCR1 to TSnCCR4 registers to set the duty ratio of 100%. These settings enable chopping output control and rectangular output control.

# (i) Pattern output switch timing, pattern output order, and initial output pattern setting

[Pattern switch method]

The pattern switch method is enabled by setting TSnPOT of the TSnOPT5 register to 0.

Output of the TOSn1 to TOSn6 pins is switched when the TAPTSn2 to TAPTSn0 pins change.

Output order at operation start is set with the TSnIDC bit of the TSnOPT7 register. Initial output pattern is set with the TSnPSC bit of the TSnOPT4 register. However, setting of the TSnPSC bit is invalid after rotation direction is determined (after a value is set in the TSnTSF bit of the TSnOPT5 register).



[Trigger switch method]

Trigger switch method is enabled by setting TSnPOT of the TSnOPT5 register to 1. Output of the TOSn1 to TOSn6 pins is switched with the rise of the external input (TSnSTCI1 and TSnSTCI0 signals). Output order is set with the combination of TSnARD signal, TSnPSC bit of the TSnOPT4 register, or the TSnIDC bit of the TSnOPT7 register. Selection of the TSnARD signal or the TSnPSC bit of the TSnOPT4 register is set with the TSnPSS bit of the TSnOPT4 register. The output order is controlled with the TSnARD input signal when TSnPSS is set to 0, and controlled with the TSnPSC bit when TSnPSS is set to 1. Refer to *"Timer output pattern in each mode and function" on page 671* for the pattern output order. The initial output pattern can be controlled with the TSnIPC2 to TSnIPC0 bits of the TSnOPT4 register. The Initial pattern is output at the timer Sn operation start setting timing (when TSnCE of the TSnCTL0 register to 1) following setting with the TSnIPC2 to TSnIPC0 bit. Refer to *"Timer output initial pattern setting in each mode and function" on page 663* for details.

**Caution** Set the initial pattern by reading the input level of the port connected to the TAPTSn2 to TAPTSn0 pins.



## (4) Operation in 120° excitation mode

*Figure 17-141 on page 864* and *Figure 17-142 on page 865* show operation examples in the 120° excitation mode. TOSn1 to TOSn6 detect input level change timing of the TAPTSn2 to TAPTSn02 pins to change output pattern. The 16-bit counter operation is saw-tooth wave operation to provide PWM output by the SnCCR0 to TSnCCR4 registers. The 16-bit counter is not cleared to 0000H until the match with the TSnCCR0 register value in the PWM cycle even if change of the TAPTSn2 to TAPTSn0 pins is detected. The timer output pattern is switched from the cycle following the PWM cycle where the change of the TAPTSn2 to TAPTSn0 pins is detected.

TSnOPT4 register: TSnSOC = 0, TSnPSC = 0, TSnOPT5 register: TSnADC = 0, TSnPOT = 0, TSnOPT7 register: TSnIDC = 0



## Figure 17-141 120° excitation mode basic operation timing example (pattern switch method, normal rotation)



**Note** PWM1 to PWM4 indicate the PWM operation set with the TSnCCR1 to TSnCCR4 registers.

## Chapter 17





# Figure 17-142 120° excitation mode basic operation timing example (pattern switch method, reverse rotation)



**Note** PWM1 to PWM4 indicate the PWM operation set with the TSnCCR1 to TSnCCR4 registers.

Pattern switch order

## (5) Output pattern list in 120° excitation mode

In the 120° excitation mode, the output pattern is determined by the rotation direction and the TSnIDC bit of the TSnOPT7 register.

| TSnOPT | 5 register | - Rotation direction   |  |  |  |
|--------|------------|------------------------|--|--|--|
| TSnPOT | TSnPSS     | Hotation direction     |  |  |  |
| 0      | -          | TSnTSF flag            |  |  |  |
| 1      | 0          | Input signal to TSnARD |  |  |  |
| 1      | 1          | TSnPSC bit             |  |  |  |

Normal rotation: TSnOPT4 register: TSnSOC = 0, TSnPSC = 0, TSnOPT5 register: TSnADC = 0, TSnPOT = 1, TSnPSS = 1, and TSnOPT7 register: TSnIDC = 0

|            |            |             |            | Pattern switch order     |                       |           |            |             |
|------------|------------|-------------|------------|--------------------------|-----------------------|-----------|------------|-------------|
| Output pin | TSnIPC2 to | o TSnIPC0 c | of TSnOPT4 | register <sup>Note</sup> | <sup>1</sup> /TSnOPF2 | to TSnOPF | 0 of TSnOP | T5 register |
| Output pin | [1, 0, 1]  | [1, 0, 0]   | [1, 1, 0]  | [0, 1, 0]                | [0, 1, 1]             | [0, 0, 1] | [0, 0, 0]  | [1, 1, 1]   |
| TOSn1      | PWM1       | PWM2        | INACT      | INACT                    | INACT                 | INACT     | Note 2     | Note 3      |
| TOSn2      | INACT      | INACT       | INACT      | PWM3                     | PWM4                  | INACT     | Note 2     | Note 3      |
| TOSn3      | INACT      | INACT       | PWM1       | PWM2                     | INACT                 | INACT     | Note 2     | Note 3      |
| TOSn4      | PWM4       | INACT       | INACT      | INACT                    | INACT                 | PWM3      | Note 2     | Note 3      |
| TOSn5      | INACT      | INACT       | INACT      | INACT                    | PWM1                  | PWM2      | Note 2     | Note 3      |
| TOSn6      | INACT      | PWM3        | PWM4       | INACT                    | INACT                 | INACT     | Note 2     | Note 3      |

Normal rotation: TSnOPT4 register: TSnSOC = 0, TSnPSC = 0, TSnOPT5 register: TSnADC = 0, TSnPOT = 1, TSnPSS = 1, and TSnOPT7 register: TSnIDC = 1

|             |           |            |           | Fal        | lem switch o | luei      |           |           |
|-------------|-----------|------------|-----------|------------|--------------|-----------|-----------|-----------|
| Output pin  | TSnIPC2   | to TSnIPC0 | of TSnOPT | F0 of TSnO | TSnOPT5 mode |           |           |           |
| Output pill | [1, 0, 1] | [1, 0, 0]  | [1, 1, 0] | [0, 1, 0]  | [0, 1, 1]    | [0, 0, 1] | [0, 0, 0] | [1, 1, 1] |
| TOSn1       | INACT     | INACT      | INACT     | PWM1       | PWM2         | INACT     | Note 2    | Note 3    |
| TOSn2       | PWM3      | PWM4       | INACT     | INACT      | INACT        | INACT     | Note 2    | Note 3    |
| TOSn3       | PWM2      | INACT      | INACT     | INACT      | INACT        | PWM1      | Note 2    | Note 3    |
| TOSn4       | INACT     | INACT      | PWM3      | PWM4       | INACT        | INACT     | Note 2    | Note 3    |
| TOSn5       | INACT     | PWM1       | PWM2      | INACT      | INACT        | INACT     | Note 2    | Note 3    |
| TOSn6       | INACT     | INACT      | INACT     | INACT      | PWM3         | PWM4      | Note 2    | Note 3    |

- **Note** 1. The output pattern of TSnIPC2 to TSnIPC0 is changed by writing when TSnPOT = 1. Then, output is switched according to the pattern switch order when the pattern switch trigger is generated by the rise of TSnSTCI0 and TSnSTCI1. In this case, TSnIPC2 to TSnIPC0 do not change even if the output pattern is switched.
  - 2. INACT if no change from the initial value. If the value is changed from any value to [0, 0, 0], the output remains the level before the change.
  - 3. Output remains the level before the change.
  - 4. PWM1 to PWM4: PWM output of the TSnCCR1 to TSnCCR4 registers



Pattern switch order

## 5. INACT: Inactive level output

Reverse rotation: TSnOPT4 register: TSnSOC = 0, TSnPSC = 1, TSnOPT5 register: TSnADC = 0, TSnPOT = 1, TSnPSS = 1, and TSnOPT7 register: TSnIDC = 0

|            | ←                                                                                                   |           |           |           |           | Patte     | ern switch o | rder      |  |  |  |  |
|------------|-----------------------------------------------------------------------------------------------------|-----------|-----------|-----------|-----------|-----------|--------------|-----------|--|--|--|--|
| Output Pin | TSnIPC2 to TSnIPC0 of TSnOPT4 Register <sup>Note 1</sup> /TSnOPF2 to TSnOPF0 of TSnOPT5<br>Register |           |           |           |           |           |              |           |  |  |  |  |
|            | [1, 0, 1]                                                                                           | [1, 0, 0] | [1, 1, 0] | [0, 1, 0] | [0, 1, 1] | [0, 0, 1] | [0, 0, 0]    | [1, 1, 1] |  |  |  |  |
| TOSn1      | PWM2                                                                                                | PWM1      | INACT     | INACT     | INACT     | INACT     | Note 2       | Note 3    |  |  |  |  |
| TOSn2      | INACT                                                                                               | INACT     | INACT     | PWM4      | PWM3      | INACT     | Note 2       | Note 3    |  |  |  |  |
| TOSn3      | INACT                                                                                               | INACT     | PWM2      | PWM1      | INACT     | INACT     | Note 2       | Note 3    |  |  |  |  |
| TOSn4      | PWM3                                                                                                | INACT     | INACT     | INACT     | INACT     | PWM4      | Note 2       | Note 3    |  |  |  |  |
| TOSn5      | INACT                                                                                               | INACT     | INACT     | INACT     | PWM2      | PWM1      | Note 2       | Note 3    |  |  |  |  |
| TOSn6      | INACT                                                                                               | PWM4      | PWM3      | INACT     | INACT     | INACT     | Note 2       | Note 3    |  |  |  |  |

Reverse rotation: TSnOPT4 register: TSnSOC = 0, TSnPSC = 1, TSnOPT5 register: TSnADC = 0, TSnPOT = 1, TSnPSS = 1, and TSnOPT7 register: TSnIDC = 1

|            | <b>(</b>  |                                                                                                     | Fall      | em switch o | nuei      |           |           |           |  |  |  |  |  |
|------------|-----------|-----------------------------------------------------------------------------------------------------|-----------|-------------|-----------|-----------|-----------|-----------|--|--|--|--|--|
| Output Pin | TSnIPO    | TSnIPC2 to TSnIPC0 of TSnOPT4 Register <sup>Note 1</sup> /TSnOPF2 to TSnOPF0 of TSnOPT5<br>Register |           |             |           |           |           |           |  |  |  |  |  |
|            | [1, 0, 1] | [1, 0, 0]                                                                                           | [1, 1, 0] | [0, 1, 0]   | [0, 1, 1] | [0, 0, 1] | [0, 0, 0] | [1, 1, 1] |  |  |  |  |  |
| TOSn1      | INACT     | INACT                                                                                               | INACT     | PWM2        | PWM1      | INACT     | Note 2    | Note 3    |  |  |  |  |  |
| TOSn2      | PWM4      | PWM3                                                                                                | INACT     | INACT       | INACT     | INACT     | Note 2    | Note 3    |  |  |  |  |  |
| TOSn3      | PWM1      | INACT                                                                                               | INACT     | INACT       | INACT     | PWM2      | Note 2    | Note 3    |  |  |  |  |  |
| TOSn4      | INACT     | INACT                                                                                               | PWM4      | PWM3        | INACT     | INACT     | Note 2    | Note 3    |  |  |  |  |  |
| TOSn5      | INACT     | PWM2                                                                                                | PWM1      | INACT       | INACT     | INACT     | Note 2    | Note 3    |  |  |  |  |  |
| TOSn6      | INACT     | INACT                                                                                               | INACT     | INACT       | PWM4      | PWM3      | Note 2    | Note 3    |  |  |  |  |  |

Note 1. The output pattern of TSnIPC2 to TSnIPC0 is changed by writing when TSnPOT = 1. Then, output is switched according to the pattern switch order when the pattern switch trigger is generated by the rise of TSnSTCI0 and TSnSTCI1. In this case, TSnIPC2 to TSnIPC0 do not change even if the output pattern is switched.

- 2. INACT if no change from the initial value. If the value is changed from any value to [0, 0, 0], the output remains the level before the change.
- 3. Output remains the level before the change.
- 4. PWM1 to PWM4: PWM output of the TSnCCR1 to TSnCCR4 registers
- 5. INACT: Inactive level output



## (6) Operation start timing in $120^{\circ}$ excitation mode

In the case of the trigger switch control in the  $120^{\circ}$  excitation mode, the pattern that is set with the TSnIPC2 to TSnIPC0 bits of the TSnOPT4 register, rotation direction, and the TSnIDC bit of the TSnOPT7 register can be output. In the case of the pattern switch control (TSnPOT = 0), however, the pattern of the TAPTSn2 to TAPTSn0 pins can be detected, but the rotation direction (TSnTSF bit of the TSnOPT5 register) cannot be determined. Therefore, the initial pattern is determined with TSnPSC of the TSnOPT4 register (TSnPSS = 1 of the TSnOPT5 register) or the TSnARD signal level (TSnPSS = 0 of the TSnOPT5 register) until the rotation direction is determined.

TSnOPT4 register: TSnSOC = 0, TSnPSC = 0 (TSnARD = 0), TSnOPT5 register: TSnPOT = 0, and TSnOPT7 register: TSnIDC = 0.



Figure 17-143 Control at timer output start during normal rotation (when correct pattern is input)



TSnOPT4 register: TSnSOC = 0, TSnPSC = 1 (TSnARD = 1), TSnOPT5 register: TSnPOT = 0, and TSnOPT7 register: TSnIDC = 0.



Figure 17-144 Control at timer output start during reverse rotation (when correct pattern is input)

TSnOPT4 register: TSnSOC = 0, TSnPSC = 0 (TSnARD = 0), TSnOPT5 register: TSnPOT = 0, and TSnOPT7 register: TSnIDC = 0.



Figure 17-145 Control at timer output start during normal rotation (when error pattern is input)



TSnOPT4 register: TSnSOC = 0, TSnPSC = 1 (TSnARD = 1), TSnOPT5 register: TSnPOT = 0, and TSnOPT7 register: TSnIDC = 0.



Figure 17-146 Control at timer output start during reverse rotation (when error pattern is input)



## (7) Output switch timing in $120^{\circ}$ excitation mode

In the 120° excitation mode, the external output pattern switch timing (TSnSTCI0 and TSnSTCI1 signals, TAPTSn2 to TAPTSn0 pins) is input regardless of the 16-bit counter operation. The output switch timing is from the cycle following the cycle of external input switch timing. Therefore, PWM output is held until the current cycle is completed even if the switch timing is input from the outside.

When the TAPTSn2 to TAPTSn0 pins are changed serially within the 1st cycle in the pattern switch method, the value edge-detected just before cycle match is used and reflected to PWM output from the following cycle. If the TSnSTCI0 and TSnSTCI1 signal triggers are input several times within a cycle in the trigger switch method, the pattern is switched to the adjacent output pattern due to only once acceptance.

Rewriting of TSnIPC2 to TSnIPC0 is prior to the TSnSTCI0 and TSnSTCI1 triggers in case of both occurrences within a cycle in the trigger switch method. The value rewritten just before cycle match is reflected if TSnIPC2 to TSnIPC0 are rewritten several times in a cycle.



Figure 17-147 Output switch example (TAPTSn2 to TAPTSn0 Pins, TSnSTCI0, TSnSTCI1 signal trigger input)



Figure 17-148 Output switch example (switch with TSnIDC Bit of TSnOPT7 register)

RENESAS





Figure 17-149 Output switch example (switch with TSnPSC Bit of TSnOPT4 register)



TSnOPT4 register: TSnSOC = 0, TSnOPT5 register: TSnPOT = 1

Figure 17-150 Output switch example (switch with TSnIPC2 to TSnIPC0 bits of TSnOPT4 register)



#### (8) Compare register rewrite timing in 120° excitation mode

The operation example when the TSnCCR1 register is reloaded (rewritten) is described below.

*Figure 17-151 on page 873* shows an output example in case of rewriting the TSnCCR1 register. After change of the TSnCCR1 register, data is not transferred to the TSnCCR1 buffer register until the next reload timing (the changed data will not be valid), so that the output waveform can be obtained as set. However, rewriting the TSnCCR1 register again is prohibited during the reload is kept pending (in the period from the change of the TSnCCR1 register to the reload overwriting). Be sure to read the reload request flag (TSnRSF) to confirm 0 status before writing to the TSnCCR1 register.



Figure 17-151 Output example in case of rewriting of TSnCCR1 register



#### (9) Dead time control in 120° excitation mode

In the 120° excitation mode, dead time is added by the dead time control operation at the fall of each phase.

The dead time that is set to the TSnDTC1 register is inserted at the fall of the positive phase, and the dead time that is set to the TSnDTC0 register is inserted at the fall of the negative phase.



(TSnOPT5 register: TSnPOT bit = 1)

Figure 17-152 Output switch example (switch with TSnIPC2 to TSnIPC0 bits of TSnOPT4 register)

Caution

on Dead time control has little effect on the timer output during normal operation. However, dead time control may affect the timer output under the following conditions.

- When noise occurs in input pattern during use of the pattern switch method
- When input pattern changes earlier than PWM cycle during use of the pattern switch method
- When the output pattern is forcibly changed by changing the TSnIPC2 to TSnIPC0 bit of the TSnOPT4 register in the trigger switch method
- When the switch method is changed
- When the current direction control bit (TSnIDC bit of TSnOPT7 register) is changed
- · When software output control function is used
- When 180° excitation control is used



## (10) Output switch in 120° excitation mode

In the 120° excitation mode, the output pattern can be controlled by writing the value to the TSnIPC2 to TSnIPC0 bits of the TSnOPT4 register when the trigger switch method is used (TSnPOT of TSnOPT5 register is set to 1) and also the TSnADC bit of the TSnOPT5 register is set to 0 to control the output patterns. Dead time is secured by using hardware at the switch timing.

- **Caution** 1. The output level of the TOSn1 to TOSn6 pins before writing is kept when [1, 1, 1] or [0, 0, 0] is written to the TSnIPC2 to TSnIPC0 bits.
  - 2. Do not rewrite more than once to the TSnIPC2 to TSnIPC0 bits in a PWM cycle. If rewritten twice or more, the value just before PWM cycle match occurrence is reflected.



# (11) Operation when noise is generated in TAPTSn2 to TAPTSn0 pins in 120° excitation mode

Brushless DC motor hall sensor input is assumed for the TAPTSn2 to TAPTSn0 pins.

Noise may occur in the TAPTSn2 to TAPTSn0 pins in some systems. The operation in case of noise occurrence is described here.

Be sure to insert the noise filter circuit between the hall sensor and the TAPTSn2 to TAPTSn0 pins when designing system products.

*Figure 17-154 on page 876* illustrates the case when noise is generated in the TAPTSn2 to TAPTSn0 pins during operation in the pattern switch method.



Figure 17-153 Noise filter circuit connection example



Figure 17-154 Noise occurrence example upon level change of TAPTSn2 to TAPTSn0 pins (pattern switch method)



## (a) Change timing of input pattern change detection signal (TSnAEDO)

TSnAEDO toggles at the input pattern (TAPTSn2 to TAPTSn0) change timing

Caution Be sure to specify the rotation direction with the TSnARD signal (TSnPSS of TSnOPT5 register set to 0) or the TSnPSC bit of the TSnOPT4 register (TSnPSS of TSnOPT5 register is set to 1).

| TAPTSn2 to TAPTSn0 after change |           |           |           |           |           |           |           |           |           |
|---------------------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
|                                 |           | [0, 0, 0] | [1, 1, 1] | [1, 0, 1] | [1, 0, 0] | [1, 1, 0] | [0, 1, 0] | [0, 1, 1] | [0, 0, 1] |
| Current TAPTSn2 to              | [0, 0, 0] | -         | -         | -         | -         | -         | -         | -         | -         |
| TAPTSn0                         | [1, 1, 1] | -         | -         | -         | -         | -         | -         | -         | -         |
|                                 | [1, 0, 1] | -         | -         | -         | Toggle    | -         | -         | -         | -         |
|                                 | [1, 0, 0] | -         | -         | -         | -         | Toggle    | -         | -         | -         |
|                                 | [1, 1, 0] | -         | -         | -         | -         | -         | Toggle    | -         | -         |
|                                 | [0, 1, 0] | -         | -         | -         | -         | -         | -         | Toggle    | -         |
|                                 | [0, 1, 1] | -         | -         | -         | -         | -         | -         | -         | Toggle    |
|                                 | [0, 0, 1] | -         | -         | Toggle    | -         | -         | -         | -         | -         |

(When TSnPSC = 0, or TSnARD = 0)

### (When TSnPSC = 1, or TSnARD = 1)

|                    | TAPTSn2 to TAPTSn0 after change |           |           |           |           |           |           |           |           |  |
|--------------------|---------------------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|--|
|                    |                                 | [0, 0, 0] | [1, 1, 1] | [1, 0, 1] | [1, 0, 0] | [1, 1, 0] | [0, 1, 0] | [0, 1, 1] | [0, 0, 1] |  |
| Current TAPTSn2 to | [0, 0, 0]                       | -         | -         | -         | -         | -         | -         | -         | -         |  |
| TAPTSn0            | [1, 1, 1]                       | -         | -         | -         | -         | -         | -         | -         | -         |  |
|                    | [1, 0, 1]                       | -         | -         | -         | -         | -         | -         | -         | Toggle    |  |
|                    | [1, 0, 0]                       | -         | -         | Toggle    | -         | -         | -         | -         | -         |  |
|                    | [1, 1, 0]                       | -         | -         | -         | Toggle    | -         | -         | -         | -         |  |
|                    | [0, 1, 0]                       | -         | -         | -         | -         | Toggle    | -         | -         | -         |  |
|                    | [0, 1, 1]                       | -         | -         | -         | -         | -         | Toggle    | -         | -         |  |
|                    | [0, 0, 1]                       | -         | -         | -         | -         | -         | -         | Toggle    | -         |  |



## (b) 3-phase encode signal (TSnESG) change timing

| TSnESG toggles at the input pattern (TAPTSn2 to TAPTSn0) change timing |
|------------------------------------------------------------------------|
|------------------------------------------------------------------------|

| TAPTSn2 to TAPTSn0 after change |           |           |           |           |           |           |           |           |           |
|---------------------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
|                                 |           | [0, 0, 0] | [1, 1, 1] | [1, 0, 1] | [1, 0, 0] | [1, 1, 0] | [0, 1, 0] | [0, 1, 1] | [0, 0, 1] |
| Current TAPTSn2 to              | [0, 0, 0] | -         | -         | -         | -         | -         | -         | -         | -         |
| TAPTSn0                         | [1, 1, 1] | -         | -         | -         | -         | -         | -         | -         | -         |
|                                 | [1, 0, 1] | -         | -         | -         | Toggle    | -         | -         | -         | Toggle    |
|                                 | [1, 0, 0] | -         | -         | Toggle    | -         | Toggle    | -         | -         | -         |
|                                 | [1, 1, 0] | -         | -         | -         | Toggle    | -         | Toggle    | -         | -         |
|                                 | [0, 1, 0] | -         | -         | -         | -         | Toggle    | -         | Toggle    | -         |
|                                 | [0, 1, 1] | -         | -         | -         | -         | -         | Toggle    | -         | Toggle    |
|                                 | [0, 0, 1] | -         | -         | Toggle    | -         | -         | -         | Toggle    | -         |

## (c) Change timing of TOSn1 to TOSn6 pins

- In the case of the pattern switch method, the output pattern is changed when the input signal of the TAPTSn2 to TAPTSn0 pins<sup>Note</sup> is changed. The output switches in case of the simultaneous change of two or more pins.
- Output pattern changes at the TSnSTCI0 and TSnSTCI1 rising edges in the trigger switch method. Output also changes when writing to the TSnIPC2 to TSnIPC0<sup>Note</sup> bits of the TSnOPT4 register.
- **Note** The output level of the TOSn0 to TOSn6 pins remains the level before change when changed to [0, 0, 0] or [1, 1, 1].

## (d) TSnTSF flag change timing

• TSnTSF toggles at the input pattern (TAPTSn2 to TAPTSn0) change timing.

|                 | TAPTSn2 to TAPTSn0 after change |           |           |           |           |           |           |           |           |  |
|-----------------|---------------------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|--|
|                 |                                 | [0, 0, 0] | [1, 1, 1] | [1, 0, 1] | [1, 0, 0] | [1, 1, 0] | [0, 1, 0] | [0, 1, 1] | [0, 0, 1] |  |
| Current TAPTSn2 | [0, 0, 0]                       | -         | -         | -         | -         | -         | -         | -         | -         |  |
| to TAPTSn0      | [1, 1, 1]                       | -         | -         | -         | -         | -         | -         | -         | -         |  |
|                 | [1, 0, 1]                       | -         | -         | -         | 0         | -         | -         | -         | 1         |  |
|                 | [1, 0, 0]                       | -         | -         | 1         | -         | 0         | -         | -         | -         |  |
|                 | [1, 1, 0]                       | -         | -         | -         | 1         | -         | 0         | -         | -         |  |
|                 | [0, 1, 0]                       | -         | -         | -         | -         | 1         | -         | 0         | -         |  |
|                 | [0, 1, 1]                       | -         | -         | -         | -         | -         | 1         | -         | 0         |  |
|                 | [0, 0, 1]                       | -         | -         | 0         | -         | -         | -         | 1         | -         |  |

## (e) TSnNDF flag setting timing

• The setting timing is when two or more pins of TAPTSn2 to TAPTSn0 change simultaneously. The setting is cleared when writing 0.



## (f) TSnPRF flag setting timing

• The setting timing is when TSnTSF changes. The setting is cleared when writing 0.

## (g) TSnPEF flag setting timing

• The setting timing is when the value [0, 0, 0] or [1, 1, 1] is input to the TAPTSn2 to TAPTSn0 pins. The setting is cleared when writing 0.



## (12) Basic control flow in $120^{\circ}$ excitation mode

The 120° excitation mode includes 8 control statuses shown in *Table 17-37 on page 880*.

120° excitation control with the pattern switch method is enabled when setting TSnPOT of the TSnOPT5 register to 0.

This is defined as the phase fix control. In the phase fix control, delay from hall sensor or delay from sensor level detection to timer output needs to be considered. However, acceleration/deceleration is possible only by PWM duty change.

The 120° excitation control with the trigger switch method is used when TSnPOT = 1.

This is defined as phase variable control. In phase variable control, timer output pattern is set prior to hall sensor and acceleration/deceleration can be controlled by using the phase difference. However, phase variable control is more complex to control than phase fix control because the offset width for the hall sensor and the predicted value for the hall sensor must be considered. Refer to *"Timer Interconnection" on page 1020* for details.

The motor rotation direction can be set with the TSnPSC bit of the TSnOPT4 register when TSnPOT = 1, TSnPSS = 1 of TSnOPT5 register. Set TSnPSC = 0 in normal rotation, and TSnPSC = 1 in reverse rotation.

Control direction (acceleration/deceleration) is set with the TSnIDC bit of the TSnOPT7 register. Acceleration control is performed when the setting value is the same as the motor rotation direction (TSnPSC setting value), and deceleration control is performed when the setting value is different from the motor rotation direction.

#### Table 17-37 Timer Control Status

| Status | TSnOPT4<br>register:<br>TSnPSC | TSnOPT5<br>Register:<br>TSnTSF | TSnOPT7<br>register:<br>TSnIDC | TSnOPT5<br>register:<br>TSnPOT | Control                                      |
|--------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|----------------------------------------------|
| Α      | -                              | 0                              | 0                              | 0                              | Normal rotation/acceleration/phase fix       |
| В      | 0                              | -                              | 0                              | 1                              | Normal rotation/acceleration/phase variable  |
| С      | 0                              | -                              | 1                              | 1                              | Normal rotation/deceleration/phase variable  |
| D      | -                              | 0                              | 1                              | 0                              | Normal rotation/deceleration/phase fix       |
| E      | -                              | 1                              | 1                              | 0                              | Reverse rotation/acceleration/phase fix      |
| F      | 1                              | -                              | 1                              | 1                              | Reverse rotation/acceleration/phase variable |
| G      | 1                              | -                              | 0                              | 1                              | Reverse rotation/deceleration/phase variable |
| Н      | -                              | 1                              | 0                              | 0                              | Reverse rotation/deceleration/phase fix      |

Normally, control starts under the start status in which motor rotation stops. First, rotate the motor by using phase fix control to rotate from the stop status. Second, switch to the phase variable control to accelerate up to the high speed rotation. In the phase variable control, change the timer output earlier than the hall sensor change point in combination with timer T.

When decelerating from high speed rotation, change the control to the deceleration control by rewriting only the TSnIDC bit of the TSnOPT7 register. After decelerating revolution to the low-speed rotation, make the PWM duty smaller up to the stop status. This is the overall motor control flow. *Figure 17-155* and *Figure 17-156* show the status changes.





Figure 17-155 Status transition diagram



Figure 17-156 Relationship between status transition and motor rotation speed

**Note** V<sub>1</sub>, V<sub>4</sub>: Normal rotation/reverse rotation high-speed rotational speed V<sub>2</sub>, V<sub>3</sub>: Normal rotation/reverse rotation low-speed rotational speed



## (13) Software output control function in 120° excitation mode

In the 120° excitation mode, timer output is controlled with software control by using the TSnSOC and TSnIPC2 to TSnIPC0 bits of the TSnOPT4 register, and the TSnIDC bit of the TSnOPT7 register.

Output is switched immediately when setting TSnSOC = 1 as shown in *Figure 17-157*. The dead time period is assured by setting the dead time. Then, set TSnSOC to 0 in order to switch from the software output control to 120° excitation control. Output is held at this timing and is switched to be controlled by using the 120° excitation mode when reloading. Refer to *"Software output function" on page 936* for details on the software output control function.



Figure 17-157 Example of software output control function switched from 120° excitation mode



#### (a) Software output control procedure



Figure 17-158 Processing flow in software output control

The software output control processing procedure is described below.

- <1> Set TSnIDC to determine the rotation direction. There is a 180° phase difference in the timer output between when TSnIDC = 0 and TSnIDC = 1. In the software output control function, timer output is not changed only by rewriting the bit. However, 120° excitation control output pattern is changed if a cycle match occurs before <2>, so prevent cycle match before <2> in scheduling.
- <2> Set the pattern to be output to TSnIPC2 to TSnIPC0 and also set TSnSOC to 1 in order to provide software output.
- <3> Change the output pattern setting of TSnIPC2 to TSnIPC0 to change the timer output. The registers that can be changed during software control are as follows. TSnCTL0 register: TSnCE bit, TSnOPT1 to TSnOPT4 registers, TSnOPT7 register: TSnIDC, TSnTOS bits, TSnCCR0 to TSnCCR5 registers, TSnDTC0 register, TSnDTC1 register
- <4> Check that the reload request flag (TSnRSF) is set to 0. In case of TSnRSF = 1, do not proceed to the next step before setting TSnRSF = 0.

RENESAS

- <5> Software control release is started by setting TSnSOC = 0 (Not yet released in this step).
- <6> Set the compare register which is necessary after the release of software output control. Proceed to the next step when there is no need to change. Change the register with the reload function in this step if necessary.
- <7> Write to the TSnCCR1 register to perform reloading.
- <8> Reload is executed and software output is released.
- Caution 1. Any change of TSnIPC2 to TSnIPC0 is prohibited after setting TSnSOC to 0.
  - **2.** Be sure to perform reloading after the execution of steps <4>, <5>, <6> and <7>. Software output cannot be released if reload cannot be performed.



#### (14) 180° excitation control function in $120^\circ$ excitation mode

In the 120° excitation mode, the 180° excitation control function can be used with TSnADC and TSnPOT of the TSnOPT5 register, the TSnIPC2 to TSnIPC0 bits of the TSnOPT4 register, and the TSnIDC bit of the TSnOPT7 register. Output is switched immediately when setting TSnADC = 1 as shown in *Figure 17-159 on page 885*. The dead time period is assured by setting the dead time. Then, trigger input to the output pattern switch trigger (TSnSTCI1 and TSnSTCI0 signals or TAPTSn2 to TAPTSn0 pins) leads to the output change according to the TSnPSC bit setting of the TSnOPT4 register. Output is held when clearing TSnADC to 0. Then the function is switched to the 120° excitation mode output control upon reload.

Refer to *"180° excitation control function" on page 938* for details on 180° excitation control.



Figure 17-159 180° excitation control function switch example in 120° excitation mode







Figure 17-160 180° excitation control function processing flow



The following is the procedure for transition to 180° excitation control.

<1> TSnOPT7 register setting

Set a value to the TSnIDC bit to select the rotation direction. Set a value to the TSnPPC bit to select to enable (1) or disable (0) the pattern phase difference detection flag (TSnPPF) of input (TAPTSn2 to TAPTSn0 pins) or output (TSnOPF2 to TSnOPF0 flags) with the trigger switch method (TSnPOT of TSnOPT5 register = 1). Set a value to the TSnTDC bit to select either enable (1) or disable (0) the

TSnSTCI0, TSnSTCI1 signal simultaneous trigger detection flag (TSnTDF) with the trigger switch method.

Set a value to the TSnPTC1, TSnPTC0 bits to select either enable (1) or disable (0) for the TAPTSn2 to TAPTSn0 pin abnormal toggle detection flag (TSnPTF).

<2> TSnOPT5 register setting

Set a value to the TSnPOT bit to select the pattern output trigger. The pattern switch method where output is switched with the input pattern of TAPTSn2 to TAPTSn0 pins can be enabled by setting TSnPOT = 0, and the trigger switch method where output is switched with rising edge of TSnSTCI0, TSnSTCI1 signals can be enabled by setting TSnPOT = 1. Set a value to the TSnPSS bit to select the pattern output order switch factor.

<3> TSnOPT4 register setting

Set a value to the TSnPSC bit to select the pattern output order for TSnPSS = 1 of the TSnOPT5 register in the trigger switch method. Set a value to TSnIPC2 to TSnIPC0 to select the initial pattern for trigger switch method.

- <4> Start the 180° excitation control function by setting TSnADC = 1.
- <5> Output pattern switch

 Pattern switch method
 In the pattern switch method, output is switched with the input pattern of the TAPTSn2 to TAPTSn0 pins. However, the previous output level is held if [1, 1, 1] or [0, 0, 0] is input to the TAPTSn2 to TAPTSn0 pins.

Trigger switch method}

In the trigger switch method, output is switched with the rising edge of the TSnSTCI0 and TSnSTCI1 signals.

Set the appropriate value to TSnIPC2 to TSnIPC0 if forcible change is needed for timer output. Writing to TSnIPC2 to TSnIPC0 is prior to the rising edge of the TSnSTCI0, TSnSTCI1 signals in case of these simultaneous occurrences.

- Switch method can be changed during operation. The registers that can be rewritten during the 180° excitation control function operation are as follows. TSnCTL0 register: TSnCE bit, TSnOPT1 to TSnOPT5 registers, TSnOPT7 register, TSnCCR0 to TSnCCR5 registers, TSnDTC0 register, TSnDTC1 register
- **Caution** Setting of TSnSOC of the TSnOPT4 register = 1 and TSnADC of TSnOPT5 register = 1 is prohibited.

Note <1> to <3> can be performed in random order.



- <6> Check that the reload request flag (TSnRSF) is set to 0. If TSnRSF = 1, do not proceed to the next step before setting TSnRSF = 0.
- <7> Start the 180° excitation control function by setting TSnADC = 0. (Not yet released in this step). After the change of TSnADC to 0, the output is switched upon the switching using the pattern/trigger switch method until the reload is performed. The output can be changed by writing to TSnIPC2 to TSnIPC0.
- <8> Set the compare register that is necessary after the release of 180° excitation control. Proceed to the next step if there is no need for change. Change the register with the reload function in this step if necessary.
- <9> Write to the TSnCCR1 register to perform reloading.

<10>Reload is executed and software output is released.

**Caution** Be sure to execute reload after execution of steps <6>, <7>, <8> and <9>. Software output cannot be released if reload cannot be executed.



#### (b) 180° excitation control switch timing from 120° excitation mode

Output is switched immediately when switching from the 120° excitation mode to 180° excitation control. Dead time control by hardware is inserted if the output is reverse to the current output level. The output level is held until the reload timing when switching from 180° excitation control to the 120° excitation mode.



Figure 17-161 Output at switch timing between 120° excitation mode and 180° excitation control (in case of output reverse)



Figure 17-162 Output at switch timing between 120° excitation mode and 180° excitation control (in case of output not reversed)

The output switched during dead time count is set without waiting for the dead time count finish in case of the same phase, or is set after the dead time count finish in case of negative phase.





Figure 17-163 Output at switch timing between 120° excitation mode and 180° excitation control (during dead time count)



## 17.10.11 Special 120° excitation mode

#### (1) Overview of special 120° excitation mode

In the special 120° excitation mode, 120° excitation control is performed by detecting the external input (pattern: TAPTSn2 to TAPTSn0 pins, trigger: TSnSTCI0 signal) and by switching the timer output (TOSn1 to TOSn6 pins). Motor systems that can be controlled in the special 120° excitation mode are as follows.

- System where a hall sensor is connected at 120° intervals against the motor rotation
- System where normal/reverse rotation is possible by outputting as follows, in response to the hall sensor input



Figure 17-164 Normal/reverse rotation example

- Note 1. TSnOPT4 register: TSnSOC = 0, TSnOPT5 register: TSnPOT = 0
  - 2. The special 120° excitation mode is valid when TSnMD3 to TSnMD0 of the TSnCTL1 register are set to [1, 0, 1, 1].





Figure 17-165 Configuration diagram in special 120° excitation mode

| Table 17-38 | Output Pattern of TAPTSn2 to TAPTSn0 Pins (Normal Rotation) |
|-------------|-------------------------------------------------------------|
|-------------|-------------------------------------------------------------|

| Output | TAPTSn2 to TAPTSn0 |                   |                   |                      |                   |                   |           |           |
|--------|--------------------|-------------------|-------------------|----------------------|-------------------|-------------------|-----------|-----------|
| pin    | [1, 0, 1]          | [1, 0, 0]         | [1, 1, 0]         | [0, 1, 0]            | [0, 1, 1]         | [0, 0, 1]         | [0, 0, 0] | [1, 1, 1] |
| TOSn1  | Special pattern 1  | Special pattern 2 | Special pattern 3 | INACT                | INACT             | Special pattern 0 | Note      | Note      |
| TOSn2  | INACT              | INACT             | Special pattern 4 | Special pattern 5    | Special pattern 6 | Special pattern 7 | Note      | Note      |
| TOSn3  | INACT              | Special pattern 0 | Special pattern 1 | Special pattern 2    | Special pattern 3 | INACT             | Note      | Note      |
| TOSn4  | Special pattern 6  | Special pattern 7 | INACT             | INACT                | Special pattern 4 | Special pattern 5 | Note      | Note      |
| TOSn5  | Special pattern 3  | INACT             | INACT             | Special<br>pattern 0 | Special pattern 1 | Special pattern 2 | Note      | Note      |
| TOSn6  | Special pattern 4  | Special pattern 5 | Special pattern 6 | Special pattern 7    | INACT             | INACT             | Note      | Note      |

**Note** The output level of the TOSn0 to TOSn6 pins remains the level before change when changed to [0, 0, 0] or [1, 1, 1].



**Caution** Special pattern 3 and special pattern 4 cannot be set to be active simultaneously. Special pattern 0 and special pattern 7 cannot be set to be active simultaneously either. The simultaneous active setting results in the following operations.

- When TOSn1, TOSn3 and TOSn5 are set to be active prior to TOSn2, TOSn4, TOSn6 Only TOSn1, TOSn3 and TOSn5 are active in the simultaneous active period.
- When TOSn2, TOSn4, and TOSn6 are set to be active prior to TOSn1, TOSn3 and TOSn5 Only TOSn2, TOSn4, and TOSn6 are active in the simultaneous active period.
- When "TOSn1, TOSn3 and TOSn5" and "TOSn2, TOSn4, and TOSn6" are set to be active simultaneously Only TOSn1, TOSn3 and TOSn5 are active in the simultaneous active period.

There are two methods based on the external input in the special  $120^{\circ}$  excitation mode.

- Pattern switch method: Pattern input of 3-input (hall sensor, etc.)
- Trigger switch method: Trigger input (encoder circuit, offset, etc.)

#### (a) Pattern switch method (TSnPOT of TSnOPT5 register = 0)

Level detection is performed for the TAPTSn2 to TAPTSn0 pins (three patterns of input from hall sensor) to decode the signals after level detection. {Pattern output of the TOSn1 to TOSn6 pins (the output determined with the values of the TSnCCR1 to TSnCCR3, TSnPAT0, and TSnPAT1 registers) is selected by judging the decode result. Dead time control is performed by the operation of the dead time counter at respective phase signal fall timing to ensure dead time insertion.

With the pattern switch method, the decoded pattern is output provided by using data from the input pattern (TAPTSn2 to TAPTSn0 pins), current direction control bit (TSnIDC of the TSnOPT7 register), and TAPTSn2 to TAPTSn0 order detection flag (TSnTSF of the TSnOPT5 register). *Figure 17-166 on page 894* and *Figure 17-167 on page 895* show the timer output when the TAPTSn2 to TAPTSn0 pins are changed. The output pattern is switched to the pattern corresponding to the input if any error occurs in the input pattern when switching from input pattern 1 to input pattern 4. The pattern set with the input level of the TAPTSn2 to TAPTSn0 pins, the TSnIDC and TSnARD signals, (TSnPSS of TSnOPT5 register = 0), and the TSnPSC bit of the TSnOPT4 register (TSnPSS of TSnOPT5 register =1) are output immediately after the operation starts (TSnCE of TSnCTL0 register = 1TSnCE = 1 of TSnCTL0 register). The output pattern is determined with the TSnTSF flag instead of the TSnPSC bit after the value of the TSnTSF flag is determined.



Chapter 17

## TSnOPT4 register: TSnSOC = 0, TSnPSC = 0, TSnOPT5 register: TSnPOT = 0, and TSnOPT7 register: TSnIDC = 0.



Figure 17-166 Special 120° excitation mode operation example in use of pattern switch method (normal rotation)



Chapter 17

## TSnOPT4 register: TSnSOC = 0, TSnPSC = 1, TSnOPT5 register: TSnPOT = 0, and TSnOPT7 register: TSnIDC = 1.



Figure 17-167 Special 120° excitation mode operation example in use of pattern switch method (reverse rotation)



## (b) Trigger input switch method (TSnPOT of TSnOPT5 register = 1)

With the trigger input switch method, rise of theTSnSTCI0 and TSnSTCI1 signals is detected to generate the output switch timing. Timer output initial pattern is set with the TSnIPC2 to TSnIPC0 bits of the TSnOPT4 register. The output patterns after the initial pattern are determined with the TSnIPC2 to TSnIPC0 bits, rotation direction or the TSnIDC bit of the TSnOPT7 register. There are four patterns that can be output according to the combination of rotation direction and the TSnIDC bit.

| TSnOPT | 5 register | - Rotation direction                                         |  |
|--------|------------|--------------------------------------------------------------|--|
| TSnPOT | TSnPSS     |                                                              |  |
| 1      | 0          | Determine rotation direction by using input signal to TSnARD |  |
|        | 1          | Determine rotation direction by using TSnPSC bit             |  |

TSnOPT4 register: TSnSOC = 0, TSnPSC = 0, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 0



Figure 17-168 Special 120° excitation mode operation example in use of trigger input switch method (normal rotation)



Chapter 17

```
TSnOPT4 register: TSnSOC = 0, TSnPSC = 0,
TSnOPT5 register: TSnPOT = 1, TSnPSS = 1,
TSnOPT7 register: TSnIDC = 1
```



Figure 17-169 Special 120° excitation mode operation example in use of trigger input switch method (reverse rotation)





- Figure 17-170 Basic operation flow in special 120° excitation mode
  - **Note** The 16-bit counter is not cleared upon a match between the values of the 16-bit counter and the TSnCCR1 to TSnCCR5 buffer registers.



## (2) Special $120^{\circ}$ excitation mode operation List

## (a) Register rewriting

| Register              | Rewriting<br>method | Rewriting during operation                | Function                             |
|-----------------------|---------------------|-------------------------------------------|--------------------------------------|
| TSnCCR0               | Reload              | Possible                                  | Cycle                                |
| TSnCCR1 to<br>TSnCCR3 | Reload              | Possible                                  | PWM duty                             |
| TSnCCR4,<br>TSnCCR5   | Reload              | Possible                                  | Possible to select as<br>A/D trigger |
| TSnDTC0,<br>TSnDTC1   | Reload              | Conditionally<br>possible <sup>Note</sup> | Dead time                            |
| TSnPAT0, TSnPAT1      | Reload              | Possible                                  | Special pattern setting              |

**Note** Refer to *"Rewriting of TSnDTC0 and TSnDTC1 registers" on page 827* for details.

## (b) Input pin

| Pin                          | Function                   |
|------------------------------|----------------------------|
| TTRGSn                       | -                          |
| TEVTSn                       | -                          |
| TAPTSn2 to<br>TAPTSn0        | Pattern input              |
| TSnSTCI0,<br>TSnSTCI1 signal | Trigger input              |
| TSnARD signal                | Pattern change order input |

## (c) Output pin

| Pin   | Function                                                                                |
|-------|-----------------------------------------------------------------------------------------|
| TOSn0 | Toggle output by TSnCCR0 compare match                                                  |
| TOSn1 | Special pattern output (with dead time) by TSnCCR1 to TSnCCR3 compare match and TSnPAT0 |
| TOSn2 | Special pattern output (with dead time) by TSnCCR1 to TSnCCR3 compare match and TSnPAT1 |
| TOSn3 | Special pattern output (with dead time) by TSnCCR1 to TSnCCR3 compare match and TSnPAT0 |
| TOSn4 | Special pattern output (with dead time) by TSnCCR1 to TSnCCR3 compare match and TSnPAT1 |
| TOSn5 | Special pattern output (with dead time) by TSnCCR1 to TSnCCR3 compare match and TSnPAT0 |
| TOSn6 | Special pattern output (with dead time) by TSnCCR1 to TSnCCR3 compare match and TSnPAT1 |
| TOSn7 | Pulse output by A/D conversion trigger                                                  |



## (d) Interrupt

| Interrupt                 | Function                                                  |
|---------------------------|-----------------------------------------------------------|
| INTTSnCC0 to<br>INTTSnCC5 | Compare match of INTTSnCC0 to INTTSnCC5 registers         |
| INTTSnOV                  | -                                                         |
| INTTSnER                  | Error                                                     |
| INTTSnOD                  | -                                                         |
| INTTSnCD0                 | Peak interrupt (occurs at the same timing with INTTSnCC0) |
| INTTSnWN                  | Warning                                                   |

## (e) Compare match timing

| Compare match         | Timing                                                                                   |  |  |
|-----------------------|------------------------------------------------------------------------------------------|--|--|
| TSnCCR0               | Timing of switching 16-bit counter from TSnCCR0 to 0000H                                 |  |  |
| TSnCCR1 to<br>TSnCCR5 | Timing of switching 16-bit counter from "TSnCCR1 to TSnCCR5" to "TSnCCR1 to TSnCCR5 + 1" |  |  |

**Note** "-" indicates an unused function in the special 120° excitation mode.



## (3) Setting of special 120° excitation mode

#### (a) Mode setting

The special  $120^{\circ}$  excitation mode is set by setting TSnMD3 to TSnMD0 of the TSnCTL1 register to [1, 0, 1, 1].

#### (b) Output level/output enable setting

Output level/output enabling is performed by setting the TSnOL0 to TSnOL7, TSnOE0 to TSnOE7 bits of the TSnIOC0 register.

Toggle output is performed from the TOSn0 pin with the cycle match (match between 16-bit counter and TSnCCR0 register).

The TOSn7 pin output is for A/D conversion. Enable the output if necessary.

## (c) Error interrupt/warning interrupt occurrence enabling

Error interrupt (INTTSnER) occurrence is enabled by setting the TSnEOC bit of the TSnIOC4 register to 1 when positive/negative phase simultaneous active state is detected.

A warning interrupt (INTTSnWN) is enabled by setting TSnWOC of the TSnIOC4 register to 1.

#### (d) Interrupt and thinning out function setting

A peak interrupt (INTTSnCD0) occurs upon a match between the TSnCCR0 register and 16-bit counter. (Control of the TSnIOE bit of the TSnOPT1 register is invalid). Set TSnICE of the TSnOPT1 register to 1 to output a peak interrupt. To use the thinning out function or peak interrupt, execute setting with the TSnID4 to TSnID0 bits of the TSnOPT1 register.

#### (e) Reload thinning out function setting

Set TSnRDE of the TSnOPT1 register to 1 to set reload timing to the same timing with the interrupt timing.

#### (f) A/D conversion trigger output setting

To set A/D conversion trigger 0 (TSnADTRG0 signal), set whether to enable/disable upon match with the TSnCCR5 register, upon match with the TSnCCR4 register, and at peak interrupt (INTTSnCD0) by using the TSnAT04, TSnAT02, and the TSnAT01 bits of the TSnOPT2 register. To set A/D conversion trigger 1 (TSnADTRG1 signal), set whether to enable/disable upon the match with the TSnCCR5 register, upon match with

the TSnCCR4 register, and at peak interrupt (INTTSnCD0) by using the TSnAT14, TSnAT12, and TSnAT11 bits of the TSnOPT3 register. Set the compare value setting for the TSnCCR4 and TSnCCR5 registers. Thinning out function is enabled for the TSnADTRG0 and TSnADTRG1 signals.

No thinning out, 1-thinning out, 3-thinning out and 7-thinning out can be set with the TSnACC01 and TSnACC00 bits of the TSnOPT2 register, and the TSnACC11 and TSnACC10 bits of the TSnOPT3 register.



- **Caution** 1. When using the TOSn7 pin, set the TSnOPT2 and TSnOPT3 registers and the TSnCCR4 and TSnCCR5 registers appropriately according to the system.
  - Trough interrupts (INTTSnOD) do not occur in the special 120° excitation mode. Be sure to set TSnAT00, 10 bits of TSnOPT2 and TSnOPT3 registers to 0.
  - 3. The 16-bit sub-counter does not operate in the special 120° excitation mode.

Be sure to set TSnAT07, 06, TSnAT17, 16 bits of TSnOPT2, TSnOPT3 registers to 0.

 Count-down status of the 16-bit counter does not occur in the special 120° excitation mode. Be sure to set TSnAT05, 03, TSnAT15, 13 bits of TSnOPT2, TSnOPT3 registers to 0.

## (g) Dead time setting

Dead time is set with the TSnDTC0 and TSnDTC1 registers. Dead time can be calculated with the following equation. 16-bit counter operation clock cycle  $\times$  TSnDTC0 16-bit counter operation clock cycle  $\times$  TSnDTC1

The time for the change from the inactive state of the TOSn2, TOSn4, TOSn6 pins to the active state of the TOSn1, TOSn3, TOSn5 pins can be set with the TSnDTC0 register.

The time for the change from the inactive state of the TOSn1, TOSn3, TOSn5 pins to the active state of the TOSn2, TOSn4, TOSn6 pins can be set with TSnDTC1 register.

#### (h) Special pattern output setting

In the special 120° control, the output of the TOSn1, TOSn3, and TOSn5 pins is controlled with TSnCCR0 to TSnCCR3 registers, and the output of the TOSn2, TOSn4, and TOSn6 pins is controlled with TSnCCR0 to TSnCCR3, and TSnPAT1 registers. The setting enables special pattern output control.

# (i) Pattern output switch timing, pattern output order, and initial output pattern setting

[Pattern switch method]

The pattern switch method is enabled by setting TSnPOT of the TSnOPT5 register to 0. Output of pins TOSn1 to TOSn6 is switched at the change timing of the TAPTSn2 to TAPTSn0 pins.

The output order at operation start is set with the TSnIDC bit of the TSnOPT7 register. The initial output pattern is set with the TSnPSC bit of the TSnOPT4 register. However, setting with the TSnPSC bit is invalid after the rotation direction is determined (any value is set in the TSnTSF bit of the TSnOPT5 register).

[Trigger switch method]

Trigger switch method will be enabled when setting TSnPOT of TSnOPT5 register to 1.

Output of the TOSn1 to TOSn6 pins is switched with the rise of the external input (TSnSTCI1, TSnSTCI0 signals).

Output order is set in combination of TSnARD signal, TSnPSC bit of the

TSnOPT4 register, or TSnIDC bit of TSnOPT7 register.
Selection of TSnARD signal or TSnPSC bit of the TSnOPT4 register shall be set with the TSnPSS bit of the TSnOPT4 register.
Output order is controlled with the TSnARD input signal when TSnPSS is set to 0, and controlled with the TSnPSC bit when TSnPSS is set to 1. Refer to *"Timer output pattern in each mode and function" on page 671* for the pattern output order.
Initial output pattern can be controlled with the TSnIPC2 to TSnIPC0 bits of the TSnOPT4 register.
Initial pattern is output upon the timer Sn operation start setting (when TSnCE of TSnCTL0 register is set to 1) after setting with the TSnIPC2 to TSnIPC0 bit. Refer to *"Timer output initial pattern setting in each mode and function" on page 663* for details.

**Caution** Set the initial pattern by reading the input level of the port connected to the TAPTSn2 to TAPTSn0 pins.



## (4) Operation in special 120° excitation mode

*Figure 17-171 on page 904* and *Figure 17-172 on page 905* show operation examples in the special 120° excitation mode. TOSn1 to TOSn6 detect input level change timing of the TAPTSn2 to TAPTSn0 pins to change the output pattern.

The 16-bit counter operation is a saw-tooth wave operation to output a special pattern set with the TSnCCR0 to TSnCCR3, TSnPAT0, and TSnPAT1 registers. The 16-bit counter is not cleared to 0000H until matched with PWM cycle TSnCCR0 register value even if the change of the TAPTSn2 to TAPTSn0 pins is detected. Special output pattern is switched from the following PWM cycle where the change of the TAPTSn2 to TAPTSn2 to TAPTSn2 pins is detected.

TSnOPT4 register: TSnSOC = 0, TSnPSC = 0, TSnOPT5 register: TSnPOT = 0, TSnPSS = 1, TSnOPT7 register: TSnIDC = 0



Figure 17-171 Special 120° excitation mode basic operation timing example (pattern switch method, normal rotation)

**Note** Refer to *"Description of special pattern of special 120° excitation mode" on page 909* for details on the special pattern.







# Figure 17-172 Special 120° excitation mode basic operation timing example (pattern switch method, reverse rotation)

**Note** Refer to *"Description of special pattern of special 120° excitation mode" on page 909* for details on the special pattern.



## (5) Output pattern list in special 120° excitation mode

In the special 120° excitation mode, the output pattern is determined by rotation direction and the TSnIDC bit of the TSnOPT7 register.

| TSnOPT | 5 register | - Rotation direction   |  |  |
|--------|------------|------------------------|--|--|
| TSnPOT | TSnPSS     |                        |  |  |
| 0      | -          | TSnTSF flag            |  |  |
| 1      | 0          | Input signal to TSnARD |  |  |
| 1      | 1          | TSnPSC bit             |  |  |

Normal rotation: TSnOPT4 register: TSnSOC = 0, TSnPSC = 0, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 0

|        |                                                                                            |                   | Patter               | n switch or       | der               |                   |           |           |
|--------|--------------------------------------------------------------------------------------------|-------------------|----------------------|-------------------|-------------------|-------------------|-----------|-----------|
| Output | TSnOPT4 register TSnIPC2 to TSnIPC0 <sup>Note 1</sup> /TSnOPT5 register TSnOPF2 to TSnOPF0 |                   |                      |                   |                   |                   |           |           |
| pin    | [1, 0, 1]                                                                                  | [1, 0, 0]         | [1, 1, 0]            | [0, 1, 0]         | [0, 1, 1]         | [0, 0, 1]         | [0, 0, 0] | [1, 1, 1] |
| TOSn1  | Special pattern 1                                                                          | Special pattern 2 | Special pattern 3    | INACT             | INACT             | Special pattern 0 | Note 1    | Note 2    |
| TOSn2  | INACT                                                                                      | INACT             | Special pattern 4    | Special pattern 5 | Special pattern 6 | Special pattern 7 | Note 1    | Note 2    |
| TOSn3  | INACT                                                                                      | Special pattern 0 | Special<br>pattern 1 | Special pattern 2 | Special pattern 3 | INACT             | Note 1    | Note 2    |
| TOSn4  | Special pattern 6                                                                          | Special pattern 7 | INACT                | INACT             | Special pattern 4 | Special pattern 5 | Note 1    | Note 2    |
| TOSn5  | Special pattern 3                                                                          | INACT             | INACT                | Special pattern 0 | Special pattern 1 | Special pattern 2 | Note 1    | Note 2    |
| TOSn6  | Special pattern 4                                                                          | Special pattern 5 | Special pattern 6    | Special pattern 7 | INACT             | INACT             | Note 1    | Note 2    |

Normal rotation: TSnOPT4 register: TSnSOC = 0, TSnPSC = 0, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 1

|        |                   |                   |                   | Patter                     | n switch or       | der               |           |           |
|--------|-------------------|-------------------|-------------------|----------------------------|-------------------|-------------------|-----------|-----------|
| Output | TSnOP             | T4 register T     | SnIPC2 to TS      | nIPC0 <sup>Note 1</sup> /T | SnOPT5 regi       | ster TSnOPF       | 2 to TSnC | PF0       |
| pin    | [1, 0, 1]         | [1, 0, 0]         | [1, 1, 0]         | [0, 1, 0]                  | [0, 1, 1]         | [0, 0, 1]         | [0, 0, 0] | [1, 1, 1] |
| TOSn1  | INACT             | INACT             | Special pattern 0 | Special pattern 1          | Special pattern 2 | Special pattern 3 | Note 1    | Note 2    |
| TOSn2  | Special pattern 5 | Special pattern 6 | Special pattern 7 | INACT                      | INACT             | Special pattern 4 | Note 1    | Note 2    |
| TOSn3  | Special pattern 2 | Special pattern 3 | INACT             | INACT                      | Special pattern 0 | Special pattern 1 | Note 1    | Note 2    |
| TOSn4  | INACT             | Special pattern 4 | Special pattern 5 | Special pattern 6          | Special pattern 7 | INACT             | Note 1    | Note 2    |
| TOSn5  | Special pattern 0 | Special pattern 1 | Special pattern 2 | Special pattern 3          | INACT             | INACT             | Note 1    | Note 2    |
| TOSn6  | Special pattern 7 | INACT             | INACT             | Special pattern 4          | Special pattern 5 | Special pattern 6 | Note 1    | Note 2    |



| Note    | 1.             | The output pattern of TSnIPC2 to TSnIPC0 is changed by writing when TSnPOT = 1. Then, output is switched in the pattern switch order when pattern switch trigger is generated by the rise of TSnSTCI0 and TSnSTCI1. In this case, TSnIPC2 to TSnIPC0 are not changed even if the output pattern is switched.                                                                                                                                                                      |
|---------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | 2.             | INACT if no change from the initial value. If the value is changed from any value to [0, 0, 0], the output remains the level before the change.                                                                                                                                                                                                                                                                                                                                   |
|         | 3.             | Output remains the level before the change.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Caution | Sp<br>Th<br>1. | ecial pattern 3 and special pattern 4 cannot be active simultaneously.<br>ecial pattern 0 and special pattern 7 cannot be active simultaneously either.<br>e simultaneous active setting results in the following operations.<br>When TOSn1, TOSn3 and TOSn5 are set active prior to TOSn2, TOSn4,<br>and TOSn6<br>Only TOSn1, TOSn3 and TOSn5 are active in the simultaneous active<br>period.<br>When TOSn2, TOSn4, and TOSn6 are set active prior to TOSn1, TOSn3<br>and TOSn5 |
|         |                | and TOSn5<br>Only TOSn2, TOSn4, and TOSn6 are active in the simultaneous active<br>period.                                                                                                                                                                                                                                                                                                                                                                                        |
|         | 3.             | When "TOSn1, TOSn3 and TOSn5" and "TOSn2, TOSn4, and TOSn6" are<br>set active simultaneously<br>Only TOSn1, TOSn3 and TOSn5 are active in the simultaneous active<br>period.                                                                                                                                                                                                                                                                                                      |

- **Note** 1. Special pattern 0 to special pattern 7 indicate the special pattern output by TSnCCR0 to TSnCCR3, TSnPAT0, and TSnPAT1 registers.
  - 2. INACT indicates the inactive level output.

Reverse rotation: TSnOPT4 register: TSnSOC = 0, TSnPSC = 1, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 0

|        | ←                 |                                                                                            |                   |                      |                   | Patteri              | n switch or | der       |  |  |  |
|--------|-------------------|--------------------------------------------------------------------------------------------|-------------------|----------------------|-------------------|----------------------|-------------|-----------|--|--|--|
| Output | TSnOP             | TSnOPT4 register TSnIPC2 to TSnIPC0 <sup>Note 1</sup> /TSnOPT5 register TSnOPF2 to TSnOPF0 |                   |                      |                   |                      |             |           |  |  |  |
| pin    | [1, 0, 1]         | [1, 0, 0]                                                                                  | [1, 1, 0]         | [0, 1, 0]            | [0, 1, 1]         | [0, 0, 1]            | [0, 0, 0]   | [1, 1, 1] |  |  |  |
| TOSn1  | Special pattern 2 | Special pattern 1                                                                          | Special pattern 0 | INACT                | INACT             | Special pattern 3    | Note 1      | Note 2    |  |  |  |
| TOSn2  | INACT             | INACT                                                                                      | Special pattern 7 | Special pattern 6    | Special pattern 5 | Special pattern 4    | Note 1      | Note 2    |  |  |  |
| TOSn3  | INACT             | Special pattern 3                                                                          | Special pattern 2 | Special<br>pattern 1 | Special pattern 0 | INACT                | Note 1      | Note 2    |  |  |  |
| TOSn4  | Special pattern 5 | Special pattern 4                                                                          | INACT             | INACT                | Special pattern 7 | Special pattern 6    | Note 1      | Note 2    |  |  |  |
| TOSn5  | Special pattern 0 | INACT                                                                                      | INACT             | Special pattern 3    | Special pattern 2 | Special<br>pattern 1 | Note 1      | Note 2    |  |  |  |
| TOSn6  | Special pattern 7 | Special pattern 6                                                                          | Special pattern 5 | Special pattern 4    | INACT             | INACT                | Note 1      | Note 2    |  |  |  |



Pattern switch order

## Reverse rotation: TSnOPT4 register: TSnSOC = 0, TSnPSC = 1, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1, TSnOPT7 register: TSnIDC = 1

|        | •                 |                                                                                            |                   |                   | i alleri          | i switch of       | uei       |           |  |  |  |
|--------|-------------------|--------------------------------------------------------------------------------------------|-------------------|-------------------|-------------------|-------------------|-----------|-----------|--|--|--|
| Output | TSnOP             | TSnOPT4 register TSnIPC2 to TSnIPC0 <sup>Note 1</sup> /TSnOPT5 register TSnOPF2 to TSnOPF0 |                   |                   |                   |                   |           |           |  |  |  |
| pin    | [1, 0, 1]         | [1, 0, 0]                                                                                  | [1, 1, 0]         | [0, 1, 0]         | [0, 1, 1]         | [0, 0, 1]         | [0, 0, 0] | [1, 1, 1] |  |  |  |
| TOSn1  | INACT             | INACT                                                                                      | Special pattern 3 | Special pattern 2 | Special pattern 1 | Special pattern 0 | Note 1    | Note 2    |  |  |  |
| TOSn2  | Special pattern 6 | Special pattern 5                                                                          | Special pattern 4 | INACT             | INACT             | Special pattern 7 | Note 1    | Note 2    |  |  |  |
| TOSn3  | Special pattern 1 | Special pattern 0                                                                          | INACT             | INACT             | Special pattern 3 | Special pattern 2 | Note 1    | Note 2    |  |  |  |
| TOSn4  | INACT             | Special pattern 7                                                                          | Special pattern 6 | Special pattern 5 | Special pattern 4 | INACT             | Note 1    | Note 2    |  |  |  |
| TOSn5  | Special pattern 3 | Special pattern 2                                                                          | Special pattern 1 | Special pattern 0 | INACT             | INACT             | Note 1    | Note 2    |  |  |  |
| TOSn6  | Special pattern 4 | INACT                                                                                      | INACT             | Special pattern 7 | Special pattern 6 | Special pattern 5 | Note 1    | Note 2    |  |  |  |

Note 1. Output pattern of TSnIPC2 to TSnIPC0 is changed by writing when TSnPOT = 1.

Then, output is switched in the pattern switch order when a pattern switch trigger is generated by the rise of TSnSTCI0 and TSnSTCI1. In this case, TSnIPC2 to TSnIPC0 are not changed even if the output pattern is switched.

- 2. INACT if no change from the initial value. If the value is changed from any value to [0, 0, 0], the output remains the level before the change.
- 3. Output remains the level before the change.
- **Caution** Special pattern 3 and special pattern 4 cannot be set active. Special pattern 0 and special pattern 7 cannot be set active, either. The simultaneous active setting leads to the following operations.
  - 1. When TOSn1, TOSn3 and TOSn5 are set active prior to TOSn2, TOSn4, and TOSn6 Only TOSn1, TOSn3 and TOSn5 are active in the simultaneous active
  - period.
    When TOSn2, TOSn4, and TOSn6 are set active prior to TOSn1, TOSn3 and TOSn5
    Only TOSn2, TOSn4, and TOSn6 are active in the simultaneous active period.
  - 3. When "TOSn1, TOSn3 and TOSn5" and "TOSn2, TOSn4, and TOSn6" are set active simultaneously Only TOSn1, TOSn3 and TOSn5 are active in the simultaneous active period.
  - Note 1. Special patterns 0 to 7 indicate the special pattern output by the TSnCCR0 to TSnCCR3, TSnPAT0, and TSnPAT1 registers.
    - 2. INACT indicates the inactive level output.

#### (6) Description of special pattern of special 120° excitation mode

Special pattern is set with the TSnCCR0 to TSnCCR3 registers and the TSnPAT0 and TSnPAT1 registers.

The functions of the special pattern registers (TSnPAT0, TSnPAT1) are classified in 4-bit units. A special pattern is set with each 4-bit and the 8 special patterns can be executed as follows.

| Special pattern 0: | Output pattern from TSnCCR0 to TSnCCR3 registers<br>and TSnPAT0[3:0]   |
|--------------------|------------------------------------------------------------------------|
| Special pattern 1: | Output pattern from TSnCCR0 to TSnCCR3 registers<br>and TSnPAT0[7:4]   |
| Special pattern 2: | Output pattern from TSnCCR0 to TSnCCR3 registers<br>and TSnPAT0[11:8]  |
| Special pattern 3: | Output pattern from TSnCCR0 to TSnCCR3 registers<br>and TSnPAT0[15:12] |
| Special pattern 4: | Output pattern from TSnCCR0 to TSnCCR3 registers<br>and TSnPAT1[3:0]   |
| Special pattern 5: | Output pattern from TSnCCR0 to TSnCCR3 registers and TSnPAT1[7:4]      |
| Special pattern 6: | Output pattern from TSnCCR0 to TSnCCR3 registers<br>and TSnPAT1[11:8]  |
| Special pattern 7: | Output pattern from TSnCCR0 to TSnCCR3 registers and TSnPAT1[15:12]    |

In the special 120° excitation mode, output of 4 patterns can be set in the positive phase with TSnPAT0 and output of 4 patterns settable in negative phase with TSnPAT1 are possible.

In the special 120° excitation mode, priority is as follows when the same value is set to the TSnCCR0 to TSnCCR3 registers.

Output setting after TSnCCR3 match > output setting after TSnCCR2 match > output setting after TSnCCR1 match > output setting after TSnCCR0 match

Priority of every special pattern is as follows.

| Special pattern 0: | TSnPAT0[3] > TSnPAT0[2] > TSnPAT0[1] > TSnPAT0[0]     |
|--------------------|-------------------------------------------------------|
| Special pattern 1: | TSnPAT0[7] > TSnPAT0[6] > TSnPAT0[5] > TSnPAT0[4]     |
| Special pattern 2: | TSnPAT0[11] > TSnPAT0[10] > TSnPAT0[9] > TSnPAT0[8]   |
| Special pattern 3: | TSnPAT0[15] > TSnPAT0[14] > TSnPAT0[13] > TSnPAT0[12] |
| Special pattern 4: | TSnPAT1[3] > TSnPAT1[2] > TSnPAT1[1] > TSnPAT1[0]     |
| Special pattern 5: | TSnPAT1[7] > TSnPAT1[6] > TSnPAT1[5] > TSnPAT1[4]     |
| Special pattern 6: | TSnPAT1[11] > TSnPAT1[10] > TSnPAT1[9] > TSnPAT1[8]   |
| Special pattern 7: | TSnPAT1[15] > TSnPAT1[14] > TSnPAT1[13] > TSnPAT1[12] |







Figure 17-173 Special pattern setting example (1/2)



Figure 17-174 Special pattern setting example (2/2)

If the compare setting values of TSnPAT0[7] and TSnPAT0[6] are the same, TSnPAT0[7] has higher priority according to the priority order (TSnPAT0[7] > TSnPAT0[6] > TSnPAT0[5] > TSnPAT0[4]).

This applies to TSnPAT0[5] and TSnPAT0[4] as well.



#### (7) Output switch timing in special 120° excitation mode

In the special 120° excitation mode, external output pattern switch timing (TSnSTCI0 and TSnSTCI1 signals, TAPTSn2 to TAPTSn0 pins) is input regardless of the 16-bit counter operation, as shown in *Figure 17-175 on page 911*, *Figure 17-176 on page 912*, *Figure 17-177 on page 912*, and *Figure 17-178 on page 913*. The output switch timing starts from the following cycle of external input switch timing. Therefore, special pattern output will be held until the current cycle is completed even if the switch timing is input from the outside.

When the TAPTSn2 to TAPTSn0 pins are changed serially within the first cycle in the pattern switch method, the edge-detection value just before the cycle match is used and reflected to the special pattern output from the following cycle.

If the TSnSTCI0 and TSnSTCI1 signal triggers are input several times within a cycle in the trigger switch method, the pattern is switched to adjacent output pattern due to only once acceptance.

Rewriting of TSnIPC2 to TSnIPC0 is performed prior to the TSnSTCI0, TSnSTCI1 trigger if both occur within a cycle in the trigger switch method. The value rewritten just before cycle match is reflected if TSnIPC2 to TSnIPC0 are rewritten several times in a cycle.



Figure 17-175 Output switch example (TAPTSn2 to TAPTSn0 pins, TSnSTCI0, TSnSTCI1 signal trigger input)





Figure 17-176 Output switch example (switch with TSnIDC bit of TSnOPT7 register)



Figure 17-177 Output switch example (switch with TSnPSC bit of TSnOPT4 register)



## Chapter 17

## TSnOPT4 register: TSnPSC = 0, TSnOPT5 register: TSnPOT = 1, TSnPSS = 1



Figure 17-178 Output switch example (switch with TSnIPC2 to TSnIPC0 bits of TSnOPT4 register)



## (8) Compare register rewrite timing in special 120° excitation mode

An operation example when the TSnCCR1 register is reloaded (batch rewriting) is described below.

*Figure 17-179 on page 914* shows an output example in case of rewriting of the TSnCCR1 register.

After change of the TSnCCR1 register, data is not transferred to the TSnCCR1 buffer register until the next reload timing (the changed data will not be valid), so that the output waveform can be obtained as set. However, rewriting the TSnCCR1 register again is prohibited during the reload pending (in the period from changing the TSnCCR1 register to the batch rewriting).

Be sure to read the reload request flag (TSnRSF) to confirm 0 status when writing to the TSnCCR1 register.



Figure 17-179 Output example in case of rewriting of TSnCCR1 register



## (9) Pattern rewrite timing in special 120° excitation mode

The operation example in case of rewriting of the TSnPAT0 register is described below.

TSnPAT0 register setting value is transferred to the buffer register at reload timing after rewriting (at TSnCCR0 register match timing after writing to TSnCCR1 register). The setting is valid at the timing when the 16-bit counter is cleared. Then, the expected pattern can be output.



Figure 17-180 Pattern rewrite timing example



## (10) Dead time control in special 120° excitation mode

In the special 120° excitation mode, dead time is added by the dead time control operation at the fall of each phase.

The dead time that is set to the TSnDTC1 register is inserted at the fall of the positive phase, and the dead time that is set to the TSnDTC0 register is inserted at the fall of the negative phase.



TSnOPT4 register: TSnSOC = 0, TSnOPT5 register: TSnPOT = 1

Figure 17-181 Dead time control example

Caution

ion Dead time control has little effect on the timer output during normal operation. However, dead time control may affect the timer output under the following conditions.

- When noise occurs in input pattern during use of the pattern switch method
- When the input pattern changes earlier than PWM cycle during use of the pattern switch method
- When output pattern is forcibly changed by changing the TSnIPC2 to TSnIPC0 bits of the TSnOPT4 register in the trigger switch method
- · When the switch method is changed
- When the current direction control bit (TSnIDC bit of TSnOPT7 register) is changed
- When software output control function is used
- When 180° excitation control is used
- When special pattern 3 and special pattern 4 are set active simultaneously
- When special pattern 0 and special pattern 7 are set active simultaneously



## (11) Output switch in special 120° excitation mode

In the special 120° excitation mode, the output pattern can be controlled by writing the value to the TSnIPC2 to TSnIPC0 bits of the TSnOPT4 register when the trigger switch method is used (TSnPOT of TSnOPT5 register is set to 1) and also the TSnADC bit of the TSnOPT5 register is set to 0. Dead time is secured by using hardware at the switch timing.

- **Caution 1.** The output level of TOSn1 to TOSn6 pins is kept when [1, 1, 1] or [0, 0, 0] is written to TSnIPC2 to TSnIPC0.
  - Do not rewrite more than once the TSnIPC2 to TSnIPC0 bits in a PWM cycle. If rewritten twice or more, the value just before PWM cycle match occurrence is reflected.

#### (12) Software output control function in special 120° excitation mode

In the special 120° excitation mode, timer output control can be executed with software control by using the TSnSOC, TSnIPC2, TSnIPC1, and TSnIPC0 bits of the TSnOPT4 register, and the TSnIDC bit of the TSnOPT7 register. Refer to *"Software output control function in 120° excitation mode" on page 882* for the operation and setting procedure. Refer to *"Software output function" on page 936* for details on the software output control function.

#### (13) 180° excitation control function in special 120° excitation mode

In the special 120° excitation mode, 180° excitation control function is enabled by using the TSnADC, TSnIPC2, TSnIPC1, and TSnIPC0 bits of the TSnOPT5 register, and the TSnIDC bit of the TSnOPT7 register.

Refer to *"180° excitation control function in 120° excitation mode" on page 885* for the operation and setting procedure.

Refer to *"180° excitation control function" on page 938* for details on the 180° excitation control.



# (14) Cautions about setting of TSnPAT0, TSnPAT1 registers in special 120° excitation mode

The setting where the simultaneous active level is output to positive and negative phases is possible in the special 120° excitation mode. Practically, this means the case when bits 3 to 0 of the TSnPAT0 register and bits 15 to 12 of the TSnPAT1 register are set to any value other than [0, 0, 0, 0], or the case when bits 15 to 12 of the TSnPAT0 register and bits 3 to 0 of the TSnPAT1 register are set to any value other than [0, 0, 0, 0]. However, the following circuit operation is used because it is risky to be simultaneous active level of positive and negative phases, taking the inverter control into account. *Figure 17-182 on page 918* shows an example in case of the setting to make the TOSn1 pin and TOSn2 pin active simultaneously. In this case, the TOSn1 pin is set by priority between the TOSn3 and TOSn4 pins, and the TOSn5 pin is set by priority between the TOSn5 and TOSn6 pins.



Figure 17-182 Output Control at Simultaneous Active Occurrence



# (15) Difference between $120^{\circ}$ excitation mode and special $120^{\circ}$ excitation mode

The description of difference between the  $120^{\circ}$  excitation mode and the special  $120^{\circ}$  excitation mode are described below.

## (a) Timer output difference

120° excitation mode

Positive phase:PWM1, PWM2 output Negative phase:PWM3, PWM4 output

Special 120° excitation mode

Positive phase:Special pattern 0, special pattern 1, special pattern 2, special pattern 3

Negative phase:Special pattern 4 special pattern 5, special pattern 6, special pattern 7

## (b) Difference of electric angle that can be excited

 $120^\circ$  range of electric angle can be output during the PWM output period in the  $120^\circ$  excitation mode.

Normal rotation: TSnOPT4 register: TSnSOC = 0, TSnOPT5 register: TSnPOT = 0 TSnOPT7 register: TSnIDC = 0

Pattern switch order

| Output pin | TSnOPT4 register TSnIPC2 to TSnIPC0 <sup>Note 1</sup> /TSnOPT5 register TSnOPF2 to TSnOPF0 |           |           |           |           |           |           |           |  |  |
|------------|--------------------------------------------------------------------------------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|--|--|
| Output pin | [1, 0, 1]                                                                                  | [1, 0, 0] | [1, 1, 0] | [0, 1, 0] | [0, 1, 1] | [0, 0, 1] | [0, 0, 0] | [1, 1, 1] |  |  |
| TOSn1      | PWM1                                                                                       | PWM2      | INACT     | INACT     | INACT     | INACT     | Note 2    | Note 3    |  |  |
| TOSn2      | INACT                                                                                      | INACT     | INACT     | PWM3      | PWM4      | INACT     | Note 2    | Note 3    |  |  |
| TOSn3      | INACT                                                                                      | INACT     | PWM1      | PWM2      | INACT     | INACT     | Note 2    | Note 3    |  |  |
| TOSn4      | PWM4                                                                                       | INACT     | INACT     | INACT     | INACT     | PWM3      | Note 2    | Note 3    |  |  |
| TOSn5      | INACT                                                                                      | INACT     | INACT     | INACT     | PWM1      | PWM2      | Note 2    | Note 3    |  |  |
| TOSn6      | INACT                                                                                      | PWM3      | PWM4      | INACT     | INACT     | INACT     | Note 2    | Note 3    |  |  |

In the special 120° excitation mode, output range can be increased by  $60^{\circ}$  forward/backward respectively for the electric angle with 120° excitation control output.



Pattern switch order

## Normal rotation: TSnOPT4 register: TSnSOC = 0, TSnPSC = 0, TSnOPT5 register: TSnPOT = 0 TSnOPT7 register: TSnIDC = 0

|        |                                                                                            |                   | /                 |                   | i allen           | I SWIICH OF       | uei       |           |  |  |
|--------|--------------------------------------------------------------------------------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-----------|-----------|--|--|
| Output | TSnOPT4 register TSnIPC2 to TSnIPC0 <sup>Note 1</sup> /TSnOPT5 register TSnOPF2 to TSnOPF0 |                   |                   |                   |                   |                   |           |           |  |  |
| pin    | [1, 0, 1]                                                                                  | [1, 0, 0]         | [1, 1, 0]         | [0, 1, 0]         | [0, 1, 1]         | [0, 0, 1]         | [0, 0, 0] | [1, 1, 1] |  |  |
| TOSn1  | Special pattern 1                                                                          | Special pattern 2 | Special pattern 3 | INACT             | INACT             | Special pattern 0 | Note 1    | Note 2    |  |  |
| TOSn2  | INACT                                                                                      | INACT             | Special pattern 4 | Special pattern 5 | Special pattern 6 | Special pattern 7 | Note 1    | Note 2    |  |  |
| TOSn3  | INACT                                                                                      | Special pattern 0 | Special pattern 1 | Special pattern 2 | Special pattern 3 | INACT             | Note 1    | Note 2    |  |  |
| TOSn4  | Special pattern 6                                                                          | Special pattern 7 | INACT             | INACT             | Special pattern 4 | Special pattern 5 | Note 1    | Note 2    |  |  |
| TOSn5  | Special pattern 3                                                                          | INACT             | INACT             | Special pattern 0 | Special pattern 1 | Special pattern 2 | Note 1    | Note 2    |  |  |
| TOSn6  | Special pattern 4                                                                          | Special pattern 5 | Special pattern 6 | Special pattern 7 | INACT             | INACT             | Note 1    | Note 2    |  |  |

**Note** 1. INACT if no change from the initial value. If the value is changed from any value to [0, 0, 0], the output remains the level before the change.

2. Output remains the level before the change.

Caution Special pattern 3 and special pattern 4 cannot be active simultaneously. Special pattern 0 and special pattern 7 cannot be active simultaneously, either. The simultaneous active setting leads to the following operations.

- When TOSn1, TOSn3 and TOSn5 are set active prior to TOSn2, TOSn4, and TOSn6 Only TOSn1, TOSn3 and TOSn5 are active in the simultaneous active period.
- 2. When TOSn2, TOSn4, and TOSn6 are set active prior to TOSn1, TOSn3 and TOSn5

Only TOSn2, TOSn4, and TOSn6 are active in the simultaneous active period.

 When "TOSn1, TOSn3 and TOSn5" and "TOSn2, TOSn4, and TOSn6" are set active simultaneously Only TOSn1, TOSn3 and TOSn5 are active in the simultaneous active period.

Note 1. Each column indicates 60° of electric angle.

- 2. PWM1 to PWM4 indicate PWM output by the TSnCCR1 to TSnCCR4 registers.
- **3.** Special pattern 0 to special pattern 7 indicate the special pattern output by the TSnCCR0 to TSnCCR3, TSnPAT0, and TSnPAT1 registers.
- 4. INACT indicates the inactive level output.



# 17.10.12 Special pattern output mode

## (1) Special pattern output mode overview

16-bit counter saw-tooth wave operation and four 16-bit compare registers are used in special pattern output mode. The value that is set by the TSnPAT0 and TSnPAT1 registers is output to the TOSn0 to TOSn7 pins upon a match between the 16-bit counter and TSnCCR0 to TSnCCR3 register values.

| TSnPAT0[3:0]   | TOSn0 pin output control |
|----------------|--------------------------|
| TSnPAT0[7:4]   | TOSn1 pin output control |
| TSnPAT0[11:8]  | TOSn2 pin output control |
| TSnPAT0[15:12] | TOSn3 pin output control |
| TSnPAT1[3:0]   | TOSn4 pin output control |
| TSnPAT1[7:4]   | TOSn5 pin output control |
| TSnPAT1[11:8]  | TOSn6 pin output control |
| TSnPAT1[15:12] | TOSn7 pin output control |

**Note** Special pattern output mode is valid when TSnMD3 to TSnMD0 of TSnCTL1 register is set to [1, 1, 0, 0].



Figure 17-183 Basic operation flow in special pattern output mode

**Note** The 16-bit counter is not cleared upon a match between the values of the 16bit counter and the TSnCCR1 to TSnCCR5 buffer registers.

## (2) Special pattern output mode operation list

## (a) Register rewriting

| Register              | Rewriting<br>method | Rewriting during operation                | Function                                                   |
|-----------------------|---------------------|-------------------------------------------|------------------------------------------------------------|
| TSnCCR0               | Reload              | Possible                                  | Cycle/compare value                                        |
| TSnCCR1 to<br>TSnCCR3 | Reload              | Possible                                  | Compare value                                              |
| TSnCCR4,<br>TSnCCR5   | Reload              | Possible                                  | Compare value<br>(Selectable as A/D<br>conversion trigger) |
| TSnDTC0,<br>TSnDTC1   | Reload              | Conditionally<br>possible <sup>Note</sup> | Compare value                                              |
| TSnPAT0, TSnPAT1      | Reload              | Possible                                  | Special pattern setting                                    |

**Note** Refer to *"Rewriting of TSnDTC0 and TSnDTC1 registers" on page 827* for details.

## (b) Input pin

| Pin    | Function |
|--------|----------|
| TTRGSn | -        |
| TEVTSn | -        |

## (c) Output pin

| Pin   | Function                           |
|-------|------------------------------------|
| TOSn0 | Pattern output from TSnPAT0[3:0]   |
| TOSn1 | Pattern output from TSnPAT0[7:4]   |
| TOSn2 | Pattern output from TSnPAT0[11:8]  |
| TOSn3 | Pattern output from TSnPAT0[15:12] |
| TOSn4 | Pattern output from TSnPAT1[3:0]   |
| TOSn5 | Pattern output from TSnPAT1[7:4]   |
| TOSn6 | Pattern output from TSnPAT1[11:8]  |
| TOSn7 | Pattern output from TSnPAT1[15:12] |

## (d) Interrupt

| Interrupt                 | Function                                                         |
|---------------------------|------------------------------------------------------------------|
| INTTSnCC0 to<br>INTTSnCC5 | Compare match of TSnCCR0 to TSnCCR5 registers                    |
| INTTSnOV                  | -                                                                |
| INTTSnER                  | Error                                                            |
| INTTSnOD                  | -                                                                |
| INTTSnCD0                 | Peak interrupt (occurs at the same timing as INTTSnCC0 register) |
| INTTSnWN                  | -                                                                |

## (e) Compare match timing



| Compare match         | Timing                                                                              |
|-----------------------|-------------------------------------------------------------------------------------|
| TSnCCR0               | Timing of switching 16-bit counter from TSnCCR0 to 0000H                            |
| TSnCCR1 to<br>TSnCCR5 | Timing of switching 16-bit counter from TSnCCR1 to TSnCCR5 to TSnCCR1 to TSnCCR5 +1 |

## Note "-" indicates an unused function in the special pattern mode.



Figure 17-184 Special pattern output mode operation example

Note Write access to the TSnCCR1 register is necessary.



#### (3) Special pattern output mode setting

#### (a) Mode setting

The special pattern output mode is set by setting TSnMD4 to TSnMD0 of TSnCTL1 register to [1, 1, 0, 0].

#### (b) Output level/output enable setting

Output level/output enabling is performed by setting the TSnOL0 to TSnOL7 and TSnOE0 to TSnOE7 bits of the TSnIOC0 register. Pattern is output from the TOSn0 to TOSn7 pins.

#### (c) Error interrupt enabling

Error interrupt (INTTSnER) occurrence is enabled by setting the TSnEOC0 bit of the TSnIOC4 register to 1 when the positive/negative phase simultaneous active state is detected.

## (d) Interrupt and thinning out function setting

Peak interrupt (INTTSnCD0) occurs by match between the TSnCCR0 register and 16-bit counter. (Trough interrupt does not occur). Set TSnICE of TSnOPT1 register to 1 if the peak interrupt is necessary. To use the thinning out function for peak interrupt, execute setting with the TSnID4 to TSnID0 bits of the TSnOPT1 register.

#### (e) Reload thinning out function setting

Set reload timing to the same timing as interrupt timing by setting the TSnRDE bit of the TSnOPT1 register to 1. Reload timing is generated by setting TSnRTE of TSnOPT1 register to 1.

Caution Write access to the TSnCCR1 register is required for reload execution.

#### (f) A/D conversion trigger output setting

To set A/D conversion trigger 0 (TSnADTRG0 signal), set enabling/disabling of match timing with the TSnCCR5 register, match timing with the TSnCCR4 register, and peak interrupt (INTTSnCD0) by using TSnAT04, TSnAT02, TSnAT01 bits of the TSnOPT2 register.

To set A/D conversion trigger 1 (TSnADTRG1 signal), set enabling/disabling of match timing with the TSnCCR5 register, match timing with the TSnCCR4 register, and peak interrupt (INTTSnCD0) by using the TSnAT14, TSnAT12, TSnAT11 bits of the TSnOPT3 register. Set the compare value of the TSnCCR4 and TSnCCR5 registers.

The thinning out function is enabled for the TSnADTRG0 and TSnADTRG1 signals. No thinning out, 1-thinning out,

3-thinning out and 7-thinning out can be set with the TSnACC01 and TSnACC00 bits of the TSnOPT2 register, and the TSnACC11 and TSnACC10 bits of the TSnOPT3 register.



- **Caution 1.** When using the TOSn7 pin, set the TSnOPT2 and TSnOPT3 registers and TSnCCR4 and TSnCCR5 registers appropriately according to the system.
  - Trough interrupts (INTTSnOD) do not occur in special pattern output mode. Be sure to set TSnAT00, 10 bits of the TSnOPT2 andTSnOPT3 registers to 0.
  - 3. Do not use the peaks/troughs of the 16-bit sub-counter in special pattern output mode. Be sure to set TSnAT07, TSnAT06, TSnAT17, and TSnAT16 bits of the TSnOPT2 and TSnOPT3 registers to 0.
  - Count-down status of the 16-bit counter does not occur in special pattern output mode. Be sure to set TSnAT05, TSnAT03, TSnAT15, TSnAT13 bits of the TSnOPT2 and TSnOPT3 registers to 0.

## (g) Output pattern setting

In the output pattern, cycle setting is possible with the TSnCCR0 register, and duty setting with the TSnCCR1 to TSnCCR3 registers. Timer output level after compare match (INTTSnCC0 to INTTSnCC3 occurrence) can be set with the TSnPAT0 and TSnPAT1 registers. In the special pattern output mode, the output pattern is controlled as follows.

| TSnPAT0[3:0]:   | TOSn0 pin output pattern setting |
|-----------------|----------------------------------|
| TSnPAT0[7:4]:   | TOSn1 pin output pattern setting |
| TSnPAT0[11:8]:  | TOSn2 pin output pattern setting |
| TSnPAT0[15:12]: | TOSn3 pin output pattern setting |
| TSnPAT1[3:0]:   | TOSn4 pin output pattern setting |
| TSnPAT1[7:4]:   | TOSn5 pin output pattern setting |
| TSnPAT1[11:8]:  | TOSn6 pin output pattern setting |
| TSnPAT1[15:12]: | TOSn7 pin output pattern setting |

#### (h) Dead time setting

Dead time is set with the TSnDTC0 and TSnDTC1 registers. Dead time can be calculated with the following equation. 16-bit counter operation clock cycle  $\times$  TSnDTC0 16-bit counter operation clock cycle  $\times$  TSnDTC1

The time for the change from the inactive state of TOSn2, TOSn4, TOSn6 pins to the active state of the TOSn1, TOSn3, TOSn5 pins can be set with the TSnDTC0 register.

The time for the change from the inactive state of TOSn1, TOSn3, TOSn5 pins to the active state of the TOSn2, TOSn4, TOSn6 pins can be set with the TSnDTC1 register.

Caution

TOSn1, TOSn3 and TOSn5 rise by priority in the setting of simultaneous rise of "TOSn1 and TOSn2", "TOSn3 and TOSn4", and "TOSn5 and TOSn6".



## (4) Special pattern output mode operation

*Figure 17-185 on page 927* and *Figure 17-186 on page 928* show an operation example in the special pattern output mode. The TSnPAT0 and TSnPAT1 register values are rewritten by using the reload mode (batch rewrite function) in *Figure 17-185 on page 927* and *Figure 17-186 on page 928*. The output level is output as set in the TSnPAT0 and TSnPAT1 registers at match timing between the values of the TSnCCR0 to TSnCCR3 registers and the 16-bit counter.

Waveforms as expected are output because the batch rewrite is executed. In the special pattern output mode, error interrupt (INTTSnER) occurs by setting TSnEOC of the TSnIOC4 register to 1 to detect the positive/negative simultaneous active state.

To generate a reload timing, write operation is necessary for the TSnCCR1 register. Therefore, write the same value to the TSnCCR1 register at last when rewriting the TSnPAT0 and TSnPAT1 registers.





Figure 17-185 Special pattern output mode operation example (without dead time)

**Note** Write access to the TSnCCR1 register is required.



Figure 17-186 Special pattern output mode operation example (with dead time)

Note Write access to the TSnCCR1 register is required.

#### (5) Dead time control in special pattern output mode

In the special pattern output mode, dead time is added by the dead time control operation at the fall of each phase when TSnDSE of the TSnOPT0 register is set to 1.

The dead time that is set to the TSnDTC1 register is inserted at the fall of the positive phase, and the dead time that is set to the TSnDTC0 register is inserted at the fall of the negative phase.

Caution Dead time control of the TOSn0 and TOS7 pins is impossible.

[Control of TOSn1, TOSn2 pins]

- 1. Dead time from the fall of the TOSn1 pin to the rise of the TOSn2 pin is assured.
- 2. The TOSn2 pin holds the inactive level when the TOSn1 pin is active level, and the TOSn1 pin holds the inactive level when the TOSn2 pin is active level.
- 3. Set the TOSn1 pin by priority if the TOSn1 and TOSn2 pins rise simultaneously.
- 4. The TOSn1 pin holds inactive level even if the TOSn1 pin setting condition is generated during the TOSn2 pin active level continued.



In cycle (1), dead time counter starts operation (with TSnDTC0 register value) from the fall of the TOSn2 pin, and controls the TOSn1 pin setting condition. In this example, there is nothing to occur because of no setting condition occurrence in the dead time period.

In cycle (2), dead time counter operates from the fall of the TOSn2 pin (with the TSnDTC0 register value). In this case, the TOSn1 pin setting condition is generated by the match with the TSnCCR3 register. However, the dead time counter is under operation, so the TOSn1 pin is set after the count completion of the dead time counter.

In cycle (3), setting conditions of the TOSn1 pin and TOSn2 pin are generated simultaneously at the start of the cycle. In this case, the TOSn1 pin is set by priority, the setting condition of TOSn2 pin is retained and an error interrupt (INTTSnER) occurs. The TOSn1 pin is cleared and the TOSn2 pin is set by the match between the TSnCCR1 register and counter. The TOSn2 pin is set after the dead time counter stops because dead time control is operated. In cycle (4), the setting conditions of the TOSn1 pin and TOSn2 pin are generated simultaneously at the start of the cycle. In this case, the TOSn1 pin is set by priority, the setting condition of the TOSn2 pin is retained and an error interrupt (INTTSnER) occurs.

Clear conditions of the TOSn1 and TOSn2 pins are generated by match with the TSnCCR1 register, and then the TOSn1 pin is cleared. This time, the retained setting condition of TOSn2 pin is cleared.



When the condition in which TOSn1 and TOSn2 pins rise simultaneously, the TOSn1 pin becomes active. However, the TOSn1 pin retains the inactive level in case of the condition occurrence in which the TOSn1 and TOSn2 pins rise simultaneously during the active level output from the TOSn2 pin. Also, an error interrupt (INTTSnER) occurs at the same time.

[Control of TOSn3 and TOSn4 pins]

The control logic is same as the relation between TOSn1 and TOSn2. When the setting conditions for the TOSn3 and TOSn4 pins occur simultaneously, the TOSn3 pin is set by priority.

[Control of TOSn5 and TOSn6 pins]

The control logic is the same as the relation between TOSn1 and TOSn2. When the setting conditions for the TOSn5 and TOSn6 pins occur simultaneously, the TOSn5 pin is set by priority.



## (6) Error interrupt in special pattern output mode (INTTSnER)

In the special pattern output mode, the positive/negative phase simultaneous active state detection function can be used by setting the TSnTBA2 to TSnTBA0 bits of TSnIOC4 register. There are the TSnTBF bit of TSnOPT6 register, or INTTSnER for detection method. The INTTTSnER operation differs according to the setting of the dead time control enabling/disabling (the TSnDSE bit of TSnOPT0 register).

| Table 17-39 | Detection Method List |
|-------------|-----------------------|
|-------------|-----------------------|

| TSnDSE of TSnOPT0<br>register      | TSnTBF bit of TSnOPT6<br>register                   | INTTSnER                                                                                         |
|------------------------------------|-----------------------------------------------------|--------------------------------------------------------------------------------------------------|
| 0<br>(Dead time control enabling)  | Set with the timer output simultaneous active state | Error interrupt is output while active output is simultaneously provided.                        |
| 1<br>(Dead time control disabling) | Set with the timer output simultaneous active state | Error interrupt is output at the timing when timer output simultaneous setting condition occurs. |



Figure 17-187 Error detection example (TSnDSE = 0) (1/2)





Figure 17-188 Error detection example (TSnDSE = 1) (2/2)

## (a) Caution about error interrupt during dead time control

When the TSnDSE bit of the TSnOPT0 register is set to 1, or the TSnTBA0, TSnTBA1 and TSnTBA2 bits of the TSnIOC4 register are set to 1, positive/negative phase simultaneous setting condition occurrence of the TOSn1, TOSn3 and TOSn5 pins and the TOSn2, TOSn4, and TOSn6 pins is the error interrupt occurrence condition. Therefore, error interrupt occurs by occurrence of positive/negative phase simultaneous setting condition even when TSnOE1, TSnOE2 of the TSnIOC0 register is set to 0 and the TOSn1, TOSn2 pins are fixed in inactive level. The positive/negative phase simultaneous active state detection flag is also set. Set TSnTBA0, TSnTBA1 and TSnTBA2 to 0 in order to prevent the above situation.

## (b) Error interrupt detail timing

*Figure 17-189 on page 933* and *Figure 17-190 on page 933* show the INTTSnER trigger output timing. In case of TSnDSE = 1 of the TSnOPT0 register, 1 clock trigger is output to INTTSnER with the following operation clock when the setting condition of timer output 2 occurs. TSnTBF = 1 of the TSnOPT6 register is set simultaneously.









Figure 17-190 Error interrupt timing (TSnDSE = 1)

Note TOSn3 and TOSn4 and TOSn5 and TOSn6 are the same as well.



## (7) Compare register rewriting operation in special pattern output mode

The compare register (TSnCCR0 to TSnCCR3) can be changed in the special pattern output mode. The change timing is the reload timing (the reload thinning out function is also enabled), so that the new setting is valid from the next reload timing after the TSnCCR1 register change.





Note TSnPAT0[7:4] = [1, 0, 0, 0] TSnPAT0[11:8] = [0, 0, 1, 0]



## (8) Pattern register rewriting operation in special pattern output mode

In the special pattern output mode, pattern setting registers (TSnPAT0, TSnPAT1) can be rewritten dynamically. The change valid timing is the reload timing (the reload thinning out function is also enabled), so that writing to the TSnCCR1 register is required in order to generate reload timing.



Figure 17-192 Pattern register rewriting operation in special pattern output mode



## 17.10.13 Software output function

The software output control function can be used in the high-accuracy T-PWM mode, PWM mode with dead time, 120° excitation mode and special 120° excitation mode. The function enables the TOSn1 to TOSn6 pins to switch 6 patterns of output with software by using the TSnSOC bit of the TSnOPT4 register, TSnIPC2 to TSnIPC0 bits, and the TSnIDC bit of the TSnOPT7 register.

The TOSn1 to TOSn6 pins are immediately switched to the software output control by switching from TSnSOC = 0 to TSnSOC = 1.

Conversely, software output control is released at the reload timing if switched from TSnSOC = 1 to TSnSOC = 0.

## Table 17-40 Register Description of Software Output Control Function

| Register               | Operation                                                                                         |
|------------------------|---------------------------------------------------------------------------------------------------|
| TSnSOC                 | TSnSOC = 1                                                                                        |
| TSnIDC                 | Set the output pattern                                                                            |
| TSnPOT, TSnPSS, TSnPSC | Setting invalid                                                                                   |
| TSnIPC0 to TSnIPC2     | Set the output pattern shown in <i>Table 17-41 on page 936</i> and <i>Table 17-42 on page 936</i> |

## Table 17-41 Software output control output pattern (TSnIDC of TSnOPT7 register = 0)

TSnOPT4 register: TSnSOC = 1, TSnSOPT7 register: TSnIDC = 0

| Output pin | TSnOPF2 to TSnOPF0 of TSnOPT5 Register |           |           |           |           |           |           |           |
|------------|----------------------------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| Output pin | [1, 0, 1]                              | [1, 0, 0] | [1, 1, 0] | [0, 1, 0] | [0, 1, 1] | [0, 0, 1] | [0, 0, 0] | [1, 1, 1] |
| TOSn1      | ACT                                    | ACT       | ACT       | INACT     | INACT     | INACT     | Note 1    | Note 2    |
| TOSn2      | INACT                                  | INACT     | INACT     | ACT       | ACT       | ACT       | Note 1    | Note 2    |
| TOSn3      | INACT                                  | INACT     | ACT       | ACT       | ACT       | INACT     | Note 1    | Note 2    |
| TOSn4      | ACT                                    | ACT       | INACT     | INACT     | INACT     | ACT       | Note 1    | Note 2    |
| TOSn5      | ACT                                    | INACT     | INACT     | INACT     | ACT       | ACT       | Note 1    | Note 2    |
| TOSn6      | INACT                                  | ACT       | ACT       | ACT       | INACT     | INACT     | Note 1    | Note 2    |

**Note** 1. INACT if no change from the initial value. If the value is changed from any value to [0, 0, 0], the output remains the level before the change.

- 2. Output remains the level before the change.
- 3. ACT:Active level output
- 4. INACT:Inactive level output

Table 17-42Software output control output pattern (TSnIDC = 1 of TSnOPT7 register)TSnOPT4 register: TSnSOC = 1, TSnOPT7 register: TSnIDC = 1

| Output pin | TSnOPF2 to TSnOPF0 of TSnOPT5 register |           |           |           |           |           |           |           |
|------------|----------------------------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| output pin | [1, 0, 1]                              | [1, 0, 0] | [1, 1, 0] | [0, 1, 0] | [0, 1, 1] | [0, 0, 1] | [0, 0, 0] | [1, 1, 1] |
| TOSn1      | INACT                                  | INACT     | INACT     | ACT       | ACT       | ACT       | Note 1    | Note 2    |
| TOSn2      | ACT                                    | ACT       | ACT       | INACT     | INACT     | INACT     | Note 1    | Note 2    |
| TOSn3      | ACT                                    | ACT       | INACT     | INACT     | INACT     | ACT       | Note 1    | Note 2    |
| TOSn4      | INACT                                  | INACT     | ACT       | ACT       | ACT       | INACT     | Note 1    | Note 2    |



| Output pin |           |             | TSnOPF2   | to TSnOPF | ) of TSnOPT | 5 register |           |           |
|------------|-----------|-------------|-----------|-----------|-------------|------------|-----------|-----------|
|            | [1, 0, 1] | [1, 0, 0]   | [1, 1, 0] | [0, 1, 0] | [0, 1, 1]   | [0, 0, 1]  | [0, 0, 0] | [1, 1, 1] |
| TOSn5      | INACT     | ACT         | ACT       | ACT       | INACT       | INACT      | Note 1    | Note 2    |
| TOSn6      | ACT       | INACT INACT |           | INACT     | ACT         | ACT        | Note 1    | Note 2    |

**Note** 1. INACT if no change from the initial value. If the value is changed from any value to [0, 0, 0], the output remains the level before the change.

- 2. Output remains the level before the change.
- 3. ACT:Active level output
- 4. INACT: Inactive level output



### 17.10.14 180° excitation control function

The 180° excitation control function is enabled in the high-accuracy T-PWM mode, 120° excitation mode and special 120° excitation mode. The function provides 6 patterns of output to the TOSn1 to TOSn6 pins by using the TSnADC bit of the TSnOPT5 register, the TSnIPC2 to TSnIPC0 bits of the TSnOPT4 register, the TSnIDC bit of the TSnOPT7 register and external trigger (TSnSTCI0, TSnSTCI1 signals or TAPTSn2 to TAPTSn0 pins). The TOSn1 to TOSn6 pins are immediately switched to 180° excitation control by switch from "TSnADC = 0" to "TSnADC = 1". Conversely, 180° excitation control is released at the reload timing if switched from TSnADC = 1 to TSnADC = 0.

#### Table 17-43 Register description of 180° excitation control function

| Register                                  | Operation                                                                                                       |
|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| TSnSOC of TSnOPT4 register                | TSnSOC = 0                                                                                                      |
| TSnIPC2 to TSnIPC0 of<br>TSnOPT4 register | Set the output pattern shown in the following <i>Table 17-44 on page 938</i> and <i>Table 17-45 on page 939</i> |
| TSnPSC of TSnOPT4 register                | Setting invalid                                                                                                 |
| TSnPSS, TSnTSF of TSnOPT5<br>register     |                                                                                                                 |
| TSnPOT of TSnOPT5 register                | Selection of pattern switch method or trigger switch method                                                     |
| TSnADC of TSnOPT5 register                | $180^{\circ}$ excitation control function is enabled with TSnADC = 1.                                           |
| TSnIDC of TSnOPT7 register                | Set the output pattern (rotation direction).                                                                    |
| TSnARD pin                                | Setting invalid                                                                                                 |

### Table 17-44 Software output control output pattern (TSnIDC = 0 of TSnOPT7 register)

TSnOPT4 register: TSnSOC = 0, TSnOPT5 register: TSnADC = 1, TSnPOT = 1, TSnOPT7 register: TSnIDC = 0

| Output pin |           |           | TSnOPF2   | to TSnOPF0 of TSnOPT5 register |           |            |            |           |  |  |  |  |  |
|------------|-----------|-----------|-----------|--------------------------------|-----------|------------|------------|-----------|--|--|--|--|--|
| Output pin | [1, 0, 1] | [1, 0, 0] | [1, 1, 0] | [0, 1, 0]                      | [0, 1, 1] | [0, 0, 1]  | [0, 0, 0]  | [1, 1, 1] |  |  |  |  |  |
| TOSn1      | ACT       | ACT       | ACT       | INACT INACT INACT Note 1       |           | Note 2     |            |           |  |  |  |  |  |
| TOSn2      | INACT     | INACT     | INACT     | ACT                            | ACT       | ACT        | Note 1     | Note 2    |  |  |  |  |  |
| TOSn3      | INACT     | INACT     | ACT       | ACT                            | ACT       | INACT      | Note 1     | Note 2    |  |  |  |  |  |
| TOSn4      | ACT       | ACT       | INACT     | INACT                          | INACT     | ACT        | ACT Note 1 |           |  |  |  |  |  |
| TOSn5      | ACT       | INACT     | INACT     | INACT                          | ACT       | ACT Note 1 |            | Note 2    |  |  |  |  |  |
| TOSn6      | INACT     | ACT       | ACT       | ACT                            | INACT     | INACT      | Note 1     | Note 2    |  |  |  |  |  |

**Note 1.** INACT if no change from the initial value. If the value is changed from any value to [0, 0, 0], the output remains the level before the change.

- 2. Output remains the level before the change.
- 3. Active level output
- 4. INACT: Inactive level output



### Table 17-45 Software Output Control Output Pattern (TSnIDC = 1 of TSnOPT7 Register)

TSnOPT4 register: TSnSOC = 0, TSnOPT5 register: TSnADC = 1, TSnPOT = 1, TSnOPT7 register: TSnIDC = 1

| Output pin |           | TSnOPF2 to TSnOPF0 of TSnOPT5 register |              |                           |           |           |           |           |  |  |  |
|------------|-----------|----------------------------------------|--------------|---------------------------|-----------|-----------|-----------|-----------|--|--|--|
| Output pin | [1, 0, 1] | [1, 0, 0]                              | [1, 1, 0]    | [0, 1, 0]                 | [0, 1, 1] | [0, 0, 1] | [0, 0, 0] | [1, 1, 1] |  |  |  |
| TOSn1      | INACT     | INACT                                  | INACT        | ACT ACT ACT Note 1        |           | Note 2    |           |           |  |  |  |
| TOSn2      | ACT       | ACT                                    | ACT ACT INAC |                           | INACT     | INACT     | Note 1    | Note 2    |  |  |  |
| TOSn3      | ACT       | ACT                                    | INACT        | INACT                     | INACT     | ACT       | Note 1    | Note 2    |  |  |  |
| TOSn4      | INACT     | INACT                                  | ACT          | ACT                       | ACT       | INACT     | Note 1    | Note 2    |  |  |  |
| TOSn5      | INACT     | ACT                                    | ACT          | CT ACT INACT INACT Note 1 |           | Note 1    | Note 2    |           |  |  |  |
| TOSn6      | ACT       | INACT                                  | IACT INACT   |                           | ACT       | ACT       | Note 1    | Note 2    |  |  |  |

**Note** 1. INACT if no change from the initial value. If the value is changed from any value to [0, 0, 0], the output remains the level before the change.

2. Output remains the level before the change.

3. ACT:Active level output

4. INACT:Inactive level output



## Chapter 18 16-bit Timer/Event Counter T (TMT)

This microcontroller has two instances of the Timer T (TMT), TMT0 to TMT1.

Note Throughout this chapter, the individual instances of Timer T are identified by "n" (n = 0 or 1), for example TTnCTL1 for the Timer Tn control register 1.

### 18.1 Features

Timer T (TMT) is a 16-bit timer/event counter that provides general-purpose functions.

Timer T can perform the following operations:

- Interval timer function
- External event count function
- One-shot pulse output function
- External trigger pulse function
- 16-bit accuracy PWM output function
- Free-running function
- Pulse width measurement function
- 2-phase encoder function
- Triangular wave PWM output function
- Offset trigger generation function

### **18.2 Function Outline**

- Capture trigger input signal × 2
- Encoder input signal × 2
- Encoder clear signal × 1
- External trigger input signal × 1
- External event input × 1
- Readable counter × 1
- Count write buffer × 1
- Capture/compare reload register × 2
- Capture/compare match interrupt × 2
- Timer Output (TO) × 2
- Capture/compare match signal × 2
- Overflow interrupt × 1
- Encoder clear interrupt × 1



## 18.3 Configuration

Timer T is configured of the following hardware.

 Table 18-1
 Timer T configuration

| Item                 | Configuration                                                                                                                                                                                                                                                            |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Counter              | 16-bit counter                                                                                                                                                                                                                                                           |
| Registers            | TMTn capture/compare registers 0, 1 (TTnCCR0, TTnCCR1)<br>TMTn counter read buffer register (TTnCNT)<br>TMTn counter write buffer register (TTnTCW)<br>TMTn capture/compare buffer registers 0, 1                                                                        |
| Timer input pins     | 7 (TITn0, TITn1, TEVTTn, TTRGTn, TENCTn0, TENCTn1, TECRTn)                                                                                                                                                                                                               |
| Timer output pins    | 2 (TOTn0, TOTn1)                                                                                                                                                                                                                                                         |
| Timer input signals  | TTTTI0, TTTTI1, TTTENC0, TTTENC1, TTTTRG, TTTEVT, TTTECR                                                                                                                                                                                                                 |
| Timer output signals | TTTTO0, TTTTO1, TTTICC0, TTTICC1, TTnEQC0, TTnEQC1                                                                                                                                                                                                                       |
| Control registers    | TMTn control registers 0, 1 (TTnCTL0 to TTnCTL2)<br>TMTn I/O control registers 0 to 3 (TTnIOC0 to TTnIOC3)<br>TMTn option registers 0 to 2 (TTnOPT0 to TTnOPT2)<br>TMTn input selection register (TAAIC2, See "TAAIC2 - Timer input control register 2" on<br>page 551.) |
| Interrupts           | Compare match interrupt (INTTTnCC0, INTTTnCC1)<br>Overflow interrupt (INTTTnOV)<br>Encoder clear interrupt (INTTTnEC)                                                                                                                                                    |

### Table 18-2List of Timer T registers (1/2)

| Address   | Register name                      | Symbol  | R/W | Man | ipulable<br>Units | e Bit | After Reset           |
|-----------|------------------------------------|---------|-----|-----|-------------------|-------|-----------------------|
|           |                                    |         |     | 1   | 8                 | 16    |                       |
| FFFFF690H | TMT0 control register 0            | TT0CTL0 | R/W | ×   | ×                 |       | 00H                   |
| FFFFF691H | TMT0 control register 1            | TT0CTL1 | R/W | ×   | ×                 |       | 00H                   |
| FFFFF692H | TMT0 control register 2            | TT0CTL2 | R/W | ×   | ×                 |       | 00H                   |
| FFFFF693H | TMT0 I/O control register 0        | TT0IOC0 | R/W | ×   | ×                 |       | 00H                   |
| FFFFF694H | TMT0 I/O control register 1        | TT0IOC1 | R/W | ×   | ×                 |       | 00H                   |
| FFFFF695H | TMT0 I/O control register 2        | TT0IOC2 | R/W | х   | ×                 |       | 00H                   |
| FFFFF696H | TMT0 I/O control register 3        | TT0IOC3 | R/W | х   | ×                 |       | 00H                   |
| FFFFF697H | TMT0 option register 0             | TT0OPT0 | R/W | х   | ×                 |       | 00H                   |
| FFFFF698H | TMT0 option register 1             | TT0OPT1 | R/W | х   | ×                 |       | 00H                   |
| FFFFF699H | TMT0 option register 2             | TT0OPT2 | R/W | х   | ×                 |       | 00H                   |
| FFFF69AH  | TMT0 capture/compare register 0    | TT0CCR0 | R/W |     |                   | ×     | 0000H                 |
| FFFFF69CH | TMT0 capture/compare register 1    | TT0CCR1 | R/W |     |                   | ×     | 0000H                 |
| FFFFF69EH | TMT0 counter read buffer register  | TT0CNT  | R   |     |                   | ×     | 0000H <sup>Note</sup> |
| FFFFF990H | TMT0 counter write buffer register | TT0TCW  | R/W |     |                   | ×     | 0000H                 |
| FFFF6A0H  | TMT1 control register 0            | TT1CTL0 | R/W | ×   | ×                 |       | 00H                   |
| FFFFF6A1H | TMT1 control register 1            | TT1CTL1 | R/W | ×   | ×                 |       | 00H                   |
| FFFFF6A2H | TMT1 control register 2            | TT1CTL2 | R/W | ×   | ×                 |       | 00H                   |
| FFFFF6A3H | TMT1 I/O control register 0        | TT1IOC0 | R/W | ×   | ×                 |       | 00H                   |



### Table 18-2 List of Timer T registers (2/2)

| Address   | Register name                      | Symbol  | R/W | Man | ipulabl<br>Units | After Reset |                       |
|-----------|------------------------------------|---------|-----|-----|------------------|-------------|-----------------------|
|           |                                    |         |     | 1   | 8                | 16          |                       |
| FFFFF6A4H | TMT1 I/O control register 1        | TT1IOC1 | R/W | ×   | ×                |             | 00H                   |
| FFFFF6A5H | TMT1 I/O control register 2        | TT1IOC2 | R/W | ×   | ×                |             | 00H                   |
| FFFFF6A6H | TMT1 I/O control register 3        | TT1IOC3 | R/W | ×   | ×                |             | 00H                   |
| FFFFF6A7H | TMT1 option register 0             | TT1OPT0 | R/W | ×   | ×                |             | 00H                   |
| FFFFF6A8H | TMT1 option register 1             | TT10PT1 | R/W | ×   | ×                |             | 00H                   |
| FFFFF6A9H | TMT1 option register 2             | TT10PT2 | R/W | ×   | ×                |             | 00H                   |
| FFFFF6AAH | TMT1 capture/compare register 0    | TT1CCR0 | R/W |     |                  | ×           | 0000H                 |
| FFFFF6ACH | TMT1 capture/compare register 1    | TT1CCR1 | R/W |     |                  | ×           | 0000H                 |
| FFFFF6AEH | TMT1 counter read buffer register  | TT1CNT  | R   |     |                  | ×           | 0000H <sup>Note</sup> |
| FFFFF9A0H | TMT1 counter write buffer register | TT1TCW  | R/W |     |                  | ×           | 0000H                 |

Note When TTnCE = 0







Figure 18-1 Block diagram of Timer T

Note 1. m = 0, 1

2. PCLKn: peripheral clocks (refer to "Clock Generator" on page 148):

| PCLK    | 0  | 1  | 2 | 3 | 4 | 5 | 7    | 9      |
|---------|----|----|---|---|---|---|------|--------|
| f [MHz] | 32 | 16 | 8 | 4 | 2 | 1 | 0.25 | 0.0625 |

#### (1) TTnCCR0 - TMTn capture/compare register 0 The TTnCCR0 register is a 16-bit register that functions both as a capture register and as a compare register. Access This registers can be read/written in 16-bit units. Address TT0CCR0: FFFFF69A<sub>H</sub> TT1CCR0: FFFFF6AA<sub>н</sub> **Initial Value** 0000<sub>H</sub>. These registers are cleared by any reset. 15 14 13 12 11 10 9 2 8 7 6 5 4 3 1 0 TTnCCR0 Compare value 0 R/W

The capture and compare functions are as follows in each mode.

| Operation mode                     | Capture/compare setting<br>of TTnCCR0 register | Rewriting method during compare           | Counter clear function                        |
|------------------------------------|------------------------------------------------|-------------------------------------------|-----------------------------------------------|
| Interval mode                      | Compare only                                   | Anytime write                             | Compare match                                 |
| External event count mode          | Compare only                                   | Anytime write                             | Compare match                                 |
| External trigger pulse output mode | Compare only                                   | Batch write<br>(Reload)                   | Compare match                                 |
| One-shot pulse mode                | Compare only                                   | Anytime write                             | Compare match                                 |
| PWM mode                           | Compare only                                   | Batch write<br>(Reload)                   | Compare match                                 |
| Free-running mode                  | Capture/compare selectable                     | Anytime write                             | -                                             |
| Pulse width measurement mode       | Capture only                                   | -                                         | External input (TITn0 pin)                    |
| Triangular wave PWM mode           | Compare only                                   | Batch write<br>(Reload) <sup>Note 1</sup> | Compare match                                 |
| Encoder compare mode               | Compare only                                   | Anytime write                             | Depends on set condition <sup>Note 2</sup>    |
| Encoder capture mode               | Capture only                                   | -                                         | -                                             |
| Encoder capture compare mode       | Compare only                                   | Anytime write                             | Depends on set<br>condition <sup>Note 2</sup> |
| Offset trigger generation mode     | Capture only                                   | -                                         | External input (TITn0 pin)                    |

#### Table 18-3 Capture/compare functions in each mode

Note 1. The batch write reload timing is the counter underflow timing only.

- 2. The condition is set with the TTnECM0 and TTnECM1 bits of the TTnCTL2 register.
- Use as compare register When TTnCE = 1, the TTnCCR0 register rewrite method differs according to the operation mode. Refer to *Table 18-3 on page 944*. (For details about the compare register rewrite operation, refer to *"Method for writing to compare register" on page 966*.)
- Use as capture register The counter value is saved to the TTnCCR0 register upon TITn0 pin input edge detection. The function to clear counters following capture differs according to the operation mode. Refer to *Table 18-3 on page 944*.

RENESAS

| (2)           | ITnCCR1 - TMTn capture/compare register 1                                                                   |  |  |  |  |  |  |  |  |  |
|---------------|-------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
|               | The TTnCCR1 register is a 16-bit register that functions both as a capture register and a compare register. |  |  |  |  |  |  |  |  |  |
| Access        | This registers can be read/written in 16-bit units.                                                         |  |  |  |  |  |  |  |  |  |
| Address       | TT0CCR1: FFFF69C <sub>H</sub><br>TT1CCR1: FFFF6AC <sub>H</sub>                                              |  |  |  |  |  |  |  |  |  |
| Initial Value | 0000 <sub>H</sub> . These registers are cleared by any reset.                                               |  |  |  |  |  |  |  |  |  |
|               | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0                                                                       |  |  |  |  |  |  |  |  |  |
| TTnCCR1       | Compare value 0                                                                                             |  |  |  |  |  |  |  |  |  |
|               | R/W                                                                                                         |  |  |  |  |  |  |  |  |  |

The capture/compare functions in each operation mode are as follows.

| Operation mode                     | Capture/compare setting<br>of TTnCCR1 register | Rewriting method<br>during compare        | Counter clear<br>function                      |
|------------------------------------|------------------------------------------------|-------------------------------------------|------------------------------------------------|
| Interval mode                      | Compare only                                   | Anytime write                             | -                                              |
| External event count mode          | Compare only                                   | Anytime write                             | -                                              |
| External trigger pulse output mode | Compare only                                   | Batch write<br>(Reload)                   | -                                              |
| One-shot pulse mode                | Compare only                                   | Anytime write                             | -                                              |
| PWM mode                           | Compare only                                   | Batch write<br>(Reload)                   | -                                              |
| Free-running mode                  | Capture/compare selectable                     | Anytime write                             | -                                              |
| Pulse width measurement mode       | Capture only                                   | -                                         | External input (TITn1<br>pin)                  |
| Triangular wave PWM mode           | Compare only                                   | Batch write<br>(Reload) <sup>Note 1</sup> | -                                              |
| Encoder compare mode               | Compare only                                   | Anytime write                             | Depends on set<br>conditions <sup>Note 2</sup> |
| Encoder capture mode               | Capture only                                   | -                                         | -                                              |
| Encoder capture compare mode       | Capture only                                   | -                                         | -                                              |
| Offset trigger generation mode     | Compare only                                   | Batch write<br>(Reload) <sup>Note 3</sup> | -                                              |

#### Table 18-4 Capture/compare functions in each mode

Note 1. The batch write reload timing is the counter underflow occurrence timing only.

- 2. The conditions are set with bits TTnECM0 and TTnECM1 of TTnCTL2 register.
- 3. The batch write reload timing is the counter's 0000H clear timing only.
- Use as compare register When TTnCE = 1, the write method of register TTnCCR1 differs according to the operation mode. Refer to *Table 18-4 on page 945*. (For details about the compare register rewrite operation, refer to *"Method for writing to compare register" on page 966*.)
- Use as capture register The counter value upon TITn1 pin input edge detection is saved to the TTnCCR1 register. The function to clear the counter following capture also differs according to the mode. Refer to *Table 18-4 on page 945*.

RENESAS

#### (3) TTnCNT - TMTn counter read buffer register

The TTnCNT register is a read buffer register that can read the counter value.

Access This register can be read only in 16-bit units.

Address TT0CNT: FFFF69E<sub>H</sub> TT1CNT: FFFFF6AE<sub>H</sub>

Initial Value 0000<sub>H</sub>. This register is cleared by any reset.

**Note** When, in the encoder compare mode, encoder capture mode, and encoder capture/compare mode, the value of the TTnCE bit is changed from "1" to "0", the value that can be read by the TTnCNT register differs according to the following conditions.

- When bit TTnECC of the TTnCTL2 register = 0, 0000H can be read.
- When bit TTnECC = 1, the value held when bit TTnCE was cleared to "0" can be read.

|        | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8     | 7      | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
|--------|----|----|----|----|----|----|---|-------|--------|----|---|---|---|---|---|---|
| TTnCNT |    |    |    |    |    |    | С | ounte | r valu | ie |   |   |   |   |   |   |
|        |    |    |    |    |    |    |   | F     | 1      |    |   |   |   |   |   |   |

#### (4) TTnTCW - TMTn counter write buffer register

The TTnTCW register is a write buffer register that can write the counter value.

The setting value is valid only in the encoder compare mode, encoder capture mode, and encoder capture/compare mode. (In all other modes, the setting value is invalid.)

Access This registers can be read/written in 16-bit units.

Address TT0TCW: FFFFF990<sub>H</sub> TT1TCW: FFFFF9A0<sub>H</sub>

Initial Value 0000<sub>H</sub>. This register is cleared by any reset.

Note When TTnECC of register TTnCTL2 = 0, the setting value is loaded to the counter when the TTnCE bit is set (to 1). (When TTnECC = 1, the counter holds its value, so it is not reloaded.)

|        | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8     | 7      | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
|--------|----|----|----|----|----|----|---|-------|--------|----|---|---|---|---|---|---|
| TTnTCW |    |    |    |    |    |    | С | ounte | r valu | ie |   |   |   |   |   |   |
|        |    |    |    |    |    |    |   | R/    | W      |    |   |   |   |   |   |   |



### **18.4 Control Registers**

### (1) TTnCTL0 - TMTn control register 0

TTnCTL0 is an 8-bit register that controls the operation of TMTn.

Access This register can be read/written in 8-bit or 1-bit units.

| Address | TT0CTL0: | FFFFF690 <sub>H</sub> |
|---------|----------|-----------------------|
|         | TT1CTL0: | FFFF6A0 <sub>H</sub>  |

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|         | 7     | 6   | 5   | 4   | 3   | 2       | 1       | 0       |
|---------|-------|-----|-----|-----|-----|---------|---------|---------|
| TTnCTL0 | TTnCE | 0   | 0   | 0   | 0   | TTnCKS2 | TTnCKS1 | TTnCKS0 |
|         | R/W   | R/W | R/W | R/W | R/W | R/W     | R/W     | R/W     |

**Caution** When TTnCE = 1, only the TTnCE bit of the TTnCTL0 register can be changed. Perform write access to the other bits using the same values.

### Table 18-5 TTnCTL0 register contents (1/2)

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|-----------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 7               | TTnCE    | Controls the timer TMTn operation.<br>0: Internal operating clock operation disabled (TMTn reset asynchronously)<br>1: Internal operating clock operation enabled                                                                                                                                                                                                               |  |  |  |
|                 |          | When bit TTnCE is set to "0", the internal operation clock of TMTn stops (fixed to low level), and TMTn is reset asynchronously.<br>When bit TTnCE is set to "1", the internal operation of TMTn is enabled from when bit TTnCE was set to "1" and count-up is performed. The time until count-up is as listed in Table TMTn Count Clock and Time Until Count-Up.               |  |  |  |
|                 |          | <ul> <li>Note: 1. In the encoder compare mode, encoder capture mode, and encoder capture/compare mode, the functions that are reset when TTnCE = 0 and TTnECC = 1 are as follows.</li> <li>Compare match detector (interrupt output low level)</li> <li>Timer output (Output inactive level)</li> <li>Edge detector for other than pins TENCTn0, TENCTn1, and TECRTn</li> </ul> |  |  |  |
|                 |          | <ul> <li>2. The following functions are not reset.</li> <li>Counter</li> <li>Flags in TTnOPT1 register</li> <li>TTnCCR0 buffer, TTnCCR1 buffer register, counter read buffer register</li> <li>TENCTn0, TENCTn1, TECRTn pin edge detector</li> </ul>                                                                                                                            |  |  |  |
|                 |          | <ul> <li>3. In modes other than the above, (in which TTnECC is fixed to 0), the functions that are reset by TTnCE = 0 are as follows.</li> <li>Internal registers other than registers that can be written from the CPU, and internal latch circuits</li> </ul>                                                                                                                 |  |  |  |



| Bit<br>position | Bit name           | Function                                                                                                                                                                                                                                                         |                            |         |                                |  |  |  |
|-----------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|---------|--------------------------------|--|--|--|
| 2 to 0          | TTnCKS2<br>TTnCKS1 | Selects the c                                                                                                                                                                                                                                                    | count clock of timer TMTn. |         |                                |  |  |  |
|                 | TTnCKS0            | TTnCKS2                                                                                                                                                                                                                                                          | TTnCKS1                    | TTnCKS0 | Internal count clock selection |  |  |  |
|                 |                    | 0                                                                                                                                                                                                                                                                | 0                          | 0       | PCLK0                          |  |  |  |
|                 |                    | 0                                                                                                                                                                                                                                                                | 0                          | 1       | PCLK1                          |  |  |  |
|                 |                    | 0                                                                                                                                                                                                                                                                | 1                          | 0       | PCLK2                          |  |  |  |
|                 |                    | 0                                                                                                                                                                                                                                                                | 1                          | 1       | PCLK3                          |  |  |  |
|                 |                    | 1                                                                                                                                                                                                                                                                | 0                          | 0       | PCLK4                          |  |  |  |
|                 |                    | 1                                                                                                                                                                                                                                                                | 0                          | 1       | PCLK5                          |  |  |  |
|                 |                    | 1                                                                                                                                                                                                                                                                | 1                          | 0       | PCLK7                          |  |  |  |
|                 |                    | 1                                                                                                                                                                                                                                                                | 1                          | 1       | PCLK9                          |  |  |  |
|                 |                    | <ul> <li>Note: 1. Set the TTnCKS[2:0] bits while TTnCE = 0.<br/>The TTnCKS[2:0] bits can be changed simultaneously when the setting of TTnCE is changed from 0 to 1.</li> <li>2. The TTnCKS[2:0] bits are valid only when TTnCTL1.TTnEEE is set to 0.</li> </ul> |                            |         |                                |  |  |  |

### Table 18-5 TTnCTL0 register contents (2/2)

### Table 18-6 TMTn Count Clock and Count Delay

| Count  | TTACKS2 | TTnCKS1 | TTnCKS0 | Count delay   |               |  |  |
|--------|---------|---------|---------|---------------|---------------|--|--|
| clocks | THICK52 | THICKST | THERSU  | Minimum       | Maximum       |  |  |
| PCLK0  | 0       | 0       | 0       |               |               |  |  |
| PCLK1  | 0       | 0       | 1       | 3 base clocks | 4 base clocks |  |  |
| PCLK2  | 0       | 1       | 0       |               |               |  |  |
| PCLK3  | 0       | 1       | 1       |               | 5 base clocks |  |  |
| PCLK4  | 1       | 0       | 0       |               |               |  |  |
| PCLK5  | 1       | 0       | 1       | 4 base clocks | +             |  |  |
| PCLK7  | 1       | 1       | 0       |               | 1 count clock |  |  |
| PCLK9  | 1       | 1       | 1       |               |               |  |  |

Note  $f_{TMTn}$ : Base clock of TMTn ( $f_{TMTn} = f_{PCLK0}$ )



| (2)           | TTnCTL1 - TMTn control register 1 |                                                                  |             |             |              |              |           |          |
|---------------|-----------------------------------|------------------------------------------------------------------|-------------|-------------|--------------|--------------|-----------|----------|
|               | The TTnC                          | TL1 regis                                                        | ter is an 8 | -bit regist | er that cor  | ntrols the o | operation | of TMTn. |
| Access        | This regis                        | ter can be                                                       | e read/writ | ten in 8-bi | t or 1-bit ι | inits.       |           |          |
| Address       | TT0CTL1<br>TT1CTL1                | TT0CTL1: FFFFF691 <sub>H</sub><br>TT1CTL1: FFFFF6A1 <sub>H</sub> |             |             |              |              |           |          |
| Initial Value | 00 <sub>H</sub> . This            | register is                                                      | cleared b   | y any res   | et.          |              |           |          |
|               | 7                                 | 6                                                                | 5           | 4           | 3            | 2            | 1         | 0        |
| TTnCTL1       | 0                                 | TTnEST                                                           | TTnEEE      | 0           | TTnMD3       | TTnMD2       | TTnMD1    | TTnMD0   |
|               | R/W                               | R/W                                                              | R/W         | R/W         | R/W          | R/W          | R/W       | R/W      |
|               |                                   |                                                                  |             |             |              |              |           |          |

**Caution** Set the TTnCTL1 register when TTnCTL0.TTnCE = 0. When TTnCE = 1, bits other than bit TTnEST (TTnEEE, TTnMD3 to TTnMD0, TTnSYE) can be written using the same value.

### Table 18-7 TTnCTL1 register contents (1/2)

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6               | TTnEST   | <ul> <li>Sets to enable/disable software trigger control.</li> <li>0: No operation/Disables software trigger control.</li> <li>1: Enables software trigger control.</li> <li>In one-shot pulse mode <ul> <li>(One-shot pulse software trigger)</li> <li>Can be made to function as a software trigger by setting TTnETS to 1 when TTnCE = 1. Always write TTnEST = 1 when TTnCE = 1.</li> </ul> </li> <li>In external trigger pulse output mode <ul> <li>(Pulse output software trigger)</li> </ul> </li> </ul>                                                                                                                                                                                                                        |
|                 |          | <ul> <li>Caution: The function operates as a software trigger by setting TTnEST to 1 during the timer TMTn operation (when TTnCTL0.TTnCE = 1). The function operates as a software trigger by setting TTnCTL0.TTnCE = 1 when the value of TTnEST is 1 while TTnCTL0.TTnCE = 0.</li> <li>Note: The TTnEST bit is always read as "0"</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                          |
| 5               | TTnEEE   | <ul> <li>Specifies count clock input.</li> <li>0: Use the clock selected with the TTnCTL0.TTnCKS[2:0] bits.</li> <li>1: Use the external clock (TEVTTn pin input edge).</li> <li>Specification of the valid edge when TTnEEE = 1 (external clock: TEVTTn pin) is set with bits TTnEES1 and TTnEES0 of TTnIOC2 register.)</li> <li>Note: The setting of bit TTnEEE is invalid in the external event count mode, encoder compare mode, encoder capture mode, encoder capture/compare mode.</li> <li>Caution: Rewrite the TTnEEE bit only when TTnCE = 0. (The same value can be written when TTnCE = 1.) The operation is not guaranteed if rewriting is performed when TTnCE = 1. If rewriting was mistakenly performed, set</li> </ul> |
|                 |          | TTnCE = 0 and then set the bit again.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

RENESAS

| Bit<br>position | Bit name         | Function               |                                                                                                                                                                                                                                              |          |        |                                    |  |  |  |  |
|-----------------|------------------|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------|------------------------------------|--|--|--|--|
| 3 to 0          | TTnMD3<br>TTnMD2 | Selects the timer mode |                                                                                                                                                                                                                                              |          |        |                                    |  |  |  |  |
|                 | TTnMD1           | TTnMD3                 | TTnMD2                                                                                                                                                                                                                                       | TTnMD1   | TTnMD0 | Internal count clock selection     |  |  |  |  |
|                 | TTnMD0           | 0                      | 0                                                                                                                                                                                                                                            | 0        | 0      | Interval mode                      |  |  |  |  |
|                 |                  | 0                      | 0                                                                                                                                                                                                                                            | 0        | 1      | External event count mode          |  |  |  |  |
|                 |                  | 0                      | 0                                                                                                                                                                                                                                            | 1        | 0      | External trigger pulse output mode |  |  |  |  |
|                 |                  | 0                      | 0                                                                                                                                                                                                                                            | 1        | 1      | One-shot pulse mode                |  |  |  |  |
|                 |                  | 0                      | 1                                                                                                                                                                                                                                            | 0        | 0      | PWM mode                           |  |  |  |  |
|                 |                  | 0                      | 1                                                                                                                                                                                                                                            | 0        | 1      | Free-running mode                  |  |  |  |  |
|                 |                  | 0                      | 1                                                                                                                                                                                                                                            | 1        | 0      | Pulse width measurement mode       |  |  |  |  |
|                 |                  | 0                      | 1                                                                                                                                                                                                                                            | 1        | 1      | Triangular wave PWM mode           |  |  |  |  |
|                 |                  | 1                      | 0                                                                                                                                                                                                                                            | 0        | 0      | Encoder compare mode               |  |  |  |  |
|                 |                  | 1                      | 0                                                                                                                                                                                                                                            | 0        | 1      | Encoder capture mode               |  |  |  |  |
|                 |                  | 1                      | 0                                                                                                                                                                                                                                            | 1        | 0      | Encoder capture compare mode       |  |  |  |  |
|                 |                  | 1                      | 1                                                                                                                                                                                                                                            | 0        | 0      | Offset trigger generation mode     |  |  |  |  |
|                 |                  |                        | Other that                                                                                                                                                                                                                                   | an above |        | Setting prohibited                 |  |  |  |  |
|                 |                  |                        |                                                                                                                                                                                                                                              |          |        |                                    |  |  |  |  |
|                 |                  |                        | Caution: Rewrite the TTnMD3 to TTnMD0 bits only when TTnCE = 0. (The same value can be written when TTnCE = 1.) The operation is not guaranteed rewriting is performed when TTnCE = 1. If rewriting was mistakenly performed, set TTnCE = 0. |          |        |                                    |  |  |  |  |

### Table 18-7 TTnCTL1 register contents (2/2)



| (3)           | TTnCTL2                | TTnCTL2 - TMTn control register 2                                |             |              |                          |              |           |          |
|---------------|------------------------|------------------------------------------------------------------|-------------|--------------|--------------------------|--------------|-----------|----------|
|               | The TTnC               | TL2 regis                                                        | ter is an 8 | B-bit regist | er that cor              | ntrols the o | operation | of TMTn. |
| Access        | This regist            | ter can be                                                       | e read/writ | ten in 8-bi  | t or 1-bit u             | inits.       |           |          |
| Address       | TT0CTL2:<br>TT1CTL2:   | TT0CTL2: FFFFF692 <sub>H</sub><br>TT1CTL2: FFFFF6A2 <sub>H</sub> |             |              |                          |              |           |          |
| Initial Value | 00 <sub>H</sub> . This | register is                                                      | cleared b   | by any res   | et.                      |              |           |          |
|               | 7                      | 6                                                                | 5           | 4            | 3                        | 2            | 1         | 0        |
| TTnCTL2       | TTnECC                 | 0                                                                | 0           | TTnLDE       | TTnECM1                  | TTnECM0      | TTnUDS1   | TTnUDS0  |
|               | R/W                    | R/W                                                              | R/W         | R/W          | R/W                      | R/W          | R/W       | R/W      |
| Caution       | 1. The set mode, e     | •                                                                |             | •            | r are valid<br>ncoder ca |              |           | •        |

settings of this register are invalid in all other modes.)

2. Set the TTnCTL2 register when TTnCTL0.TTnCE = 0. When TTnCE = 1, write access to the TTnCTL2 register can be performed with the same value.

### Table 18-8 TTnCTL2 register contents (1/2)

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                |
|-----------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7               | TTnECC   | Selection of initialization/hold of counter value.<br>0: Initialize counter value when TTnCTL0.TTnCE = 0.<br>1: Hold counter value when TTnCTL0.TTnCE = 0.                                                                                                                                                                                                              |
|                 |          | <ul> <li>When TTnECC = 0, setting TnCTL0.TTnCE = 0 causes the counter to be reset to<br/>FFFFH, the capture registers (TTnCCR0/TTnCCR1) to be reset to 0000H, and the<br/>encoder dedicated flags (TTnEOF/TTnEUF/TTnESF) to be reset to 0. When<br/>TTnECC = 0, the value of the TTnTCW register is loaded to the counter when<br/>TTnCE is set from 0 to 1.</li> </ul> |
|                 |          | <ul> <li>When TTnECC = 1, setting TnCTL0.TTnCE = 0 causes the values of the counter,<br/>capture registers (TTnCCR0/TTnCCR1), and encoder dedicated flags<br/>(TTnEOF/TTnEUF/TTnESF) to be held. When TTnECC = 1, the value of the<br/>TTnTCW register is not loaded to the counter.</li> </ul>                                                                         |
|                 |          | Note: The setting of bit TTnECC is valid in the encoder compare mode, encoder capture mode, and encoder capture/compare mode. (In all other modes, it is invalid.)                                                                                                                                                                                                      |
| 4               | TTnLDE   | <ul> <li>Enables encoder load.</li> <li>0: Disable transfer of compare setting value to counter.</li> <li>1: Enable transfer of compare setting value (TTnCCR0) to counter when underflow occurs.</li> </ul>                                                                                                                                                            |
|                 |          | <ul> <li>Note: The setting of bit TTnLDE is valid in the encoder compare mode and the encoder capture mode and bits TTnECM1 and TTnECM0 are set as follows.</li> <li>TTnECM1 = 0, TTnECM0 = 0 or 1</li> </ul>                                                                                                                                                           |
| 3               | TTnECM1  | <ul> <li>Enables encoder clear mode on match of counter and TTnCCR1 register.</li> <li>0: No clear condition.</li> <li>1: When the counter and TTnCCR1 register match, clear the counter if the next count is a down count (TTnESF = 1)</li> </ul>                                                                                                                      |
|                 |          | Note: The setting of bit TTnECM1 is valid in the encoder compare mode. (It is invalid in the encoder capture mode and encoder capture compare mode.)                                                                                                                                                                                                                    |



| Bit<br>position | Bit name           |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         | Function                                                                                                                                                                                                                                |  |  |
|-----------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 2<br>3 to 0     | TTnECM0<br>TTnUDS1 | <ul> <li>Enables encoder clear mode on match of counter and TTnCCR0 register.</li> <li>0: No clear condition.</li> <li>1: When the counter and TTnCCR0 register match, clear the counter if the next count is a down count (TTnESF = 1)</li> <li>Note: The setting of bit TTnECM0 is valid in the encoder compare mode. (It is invalid in the encoder capture mode and encoder capture compare mode.)</li> <li>Selects the encoder operation mode</li> </ul> |         |                                                                                                                                                                                                                                         |  |  |
|                 | TTnUDS0            | TTnUDS1                                                                                                                                                                                                                                                                                                                                                                                                                                                      | TTnUDS0 | Encoder operation mode                                                                                                                                                                                                                  |  |  |
|                 |                    | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0       | Upon detection of the valid edge of the A phase of encoder<br>input (TENCTn0 pin), the following count operation is<br>performed in the B phase of encoder input.<br>• When "high", count down.<br>• When "low", count up.              |  |  |
|                 |                    | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 1       | Count up upon detection of valid edge of A phase of encoder<br>input (TENCTn0 pin).<br>Count down upon detection of valid edge of B phase of<br>encoder input (TENCTn1 pin).                                                            |  |  |
|                 |                    | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0       | Count up at rising edge of A phase of encoder input<br>(TENCTn0 pin). Count down at falling edge of A phase of<br>encoder input.<br>However, count operation is performed only when B phase of<br>encoder input (TENCTn1 pin) is "low". |  |  |
|                 |                    | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 1       | Detection of both edges of phase A of encoder input<br>(TENCTn0 pin)/phase B of encoder input (TENCTn1 pin).<br>Judgment of count operation based on combination of<br>detection edge and input level.                                  |  |  |
|                 |                    | TTr                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         | S[1:0] bits are set to 10B or 11B, the settings of bits<br>EIS[1:0] are invalid, and the function is fixed to the setting for<br>th edges.                                                                                              |  |  |

### Table 18-8 TTnCTL2 register contents (2/2)



| (4)           | TTnIOC0 - TMTn I/O control register 0 |                                                                                              |             |            |               |        |        |        |  |
|---------------|---------------------------------------|----------------------------------------------------------------------------------------------|-------------|------------|---------------|--------|--------|--------|--|
|               |                                       | The TTnIOC0 register is an 8-bit register that controls timer output (TOTn0 and TOTn1 pins). |             |            |               |        |        |        |  |
| Access        | This regis                            | ter can be                                                                                   | e read/writ | ten in 8-b | it or 1-bit ι | inits. |        |        |  |
| Address       |                                       | TT0IOC0: FFFF693 <sub>H</sub><br>TT1IOC0: FFFF6A3 <sub>H</sub>                               |             |            |               |        |        |        |  |
| Initial Value | 00 <sub>H</sub> . This                | 00 <sub>H</sub> . This register is cleared by any reset.                                     |             |            |               |        |        |        |  |
|               | 7                                     | 6                                                                                            | 5           | 4          | 3             | 2      | 1      | 0      |  |
| TTnIOC0       | 0                                     | 0                                                                                            | 0           | 0          | TTnOL1        | TTnOE1 | TTnOL0 | TTnOE0 |  |
|               | R/W                                   | R/W                                                                                          | R/W         | R/W        | R/W           | R/W    | R/W    | R/W    |  |
| Caution       |                                       |                                                                                              | •           |            | L0.TTnCE      |        |        | -      |  |

### Table 18-9 TTnIOC0 register contents

| Bit<br>position | Bit name | Function                                                                                                                                                                           |
|-----------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3               | TTnOL1   | <ul><li>TOTn1 pin output level setting:</li><li>0: Normal output (Low level, when output is inactive.)</li><li>1: Inverted output (High level, when output is inactive.)</li></ul> |
| 2               | TTnOE1   | TOTn1 pin output setting:<br>0: Timer output disable (TOTn1 pin output is fixed to inactive level.)<br>1: Timer output enabled (A pulse can be output from the TOTn1 pin.)         |
| 1               | TTnOL0   | TOTn0 pin output level setting:<br>0: Normal output (Low level, when output is inactive.)<br>1: Inverted output (High level, when output is inactive.)                             |
| 0               | TTnOE0   | TOTn0 pin output setting:<br>0: Timer output disable (TOTn0 pin output is fixed to inactive level.)<br>1: Timer output enabled (A pulse can be output from the TOTn0 pin.)         |



| (5)           | TTnIOC1 - TMTn I/O control register 1                    |                                                                                                                 |             |             |              |        |        |        |  |
|---------------|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|-------------|-------------|--------------|--------|--------|--------|--|
|               |                                                          | The TTnIOC1 register is an 8-bit register that controls the valid edge of capture input (TITn1 and TITn0 pins). |             |             |              |        |        |        |  |
| Access        | This regis                                               | ter can be                                                                                                      | e read/writ | ten in 8-bi | t or 1-bit u | inits. |        |        |  |
| Address       |                                                          | TT0IOC1: FFFF694 <sub>H</sub><br>TT1IOC1: FFFF6A4 <sub>H</sub>                                                  |             |             |              |        |        |        |  |
| Initial Value | 00 <sub>H</sub> . This register is cleared by any reset. |                                                                                                                 |             |             |              |        |        |        |  |
|               | 7                                                        | 6                                                                                                               | 5           | 4           | 3            | 2      | 1      | 0      |  |
| TTnIOC1       | 0                                                        | 0                                                                                                               | 0           | 0           | TTnIS3       | TTnIS2 | TTnIS1 | TTnIS0 |  |
|               | R/W                                                      | R/W                                                                                                             | R/W         | R/W         | R/W          | R/W    | R/W    | R/W    |  |

**Caution** Set the TTnIOC1 register when TTnCTL0.TTnCE = 0. When TTnCE = 1, write access to the TTnIOC1 register can be performed with the same value.

### Table 18-10 TTnIOC1 register contents

| Bit<br>position | Bit name         | Function                                                                                                                                                                                                                                                                                                                             |                                                       |                                                                                                                                                                                            |   |   |                        |
|-----------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|------------------------|
| 3, 2            | TTnIS3<br>TTnIS2 | Specifies th                                                                                                                                                                                                                                                                                                                         | ne capture i                                          | nput (TITn1) valid edge.                                                                                                                                                                   |   |   |                        |
|                 |                  | TTnIS3                                                                                                                                                                                                                                                                                                                               | TTnIS3 TTnIS2 Capture input (TITn1) valid edge settin |                                                                                                                                                                                            |   |   |                        |
|                 |                  | 0                                                                                                                                                                                                                                                                                                                                    | 0                                                     | No edge detection (capture operation invalid)                                                                                                                                              |   |   |                        |
|                 |                  | 0                                                                                                                                                                                                                                                                                                                                    | 1                                                     | Rising edge detection                                                                                                                                                                      |   |   |                        |
|                 |                  | 1                                                                                                                                                                                                                                                                                                                                    | 0                                                     | Falling edge detection                                                                                                                                                                     |   |   |                        |
|                 |                  | 1                                                                                                                                                                                                                                                                                                                                    | 1                                                     | Both, rising and falling edge detection                                                                                                                                                    |   |   |                        |
| 1, 0            | TTnIS1<br>TTnIS0 | Capture operation is performed and capture interrupt (INTTTnCC1) is output upon<br>edge detection.<br>Note: The setting of bits TTnIS3 and TTnIS2 are valid in the free-running mode,<br>pulse width measurement mode, encoder capture mode, and encoder<br>capture compare mode.<br>Specifies the capture input (TITn0) valid edge. |                                                       |                                                                                                                                                                                            |   |   |                        |
|                 | 111100           | TTnIS1                                                                                                                                                                                                                                                                                                                               | TTnIS0                                                | Capture input (TITn0) valid edge setting                                                                                                                                                   |   |   |                        |
|                 |                  | 0                                                                                                                                                                                                                                                                                                                                    | 0                                                     | No edge detection (capture operation invalid)                                                                                                                                              |   |   |                        |
|                 |                  | 0                                                                                                                                                                                                                                                                                                                                    | 1                                                     | Rising edge detection                                                                                                                                                                      |   |   |                        |
|                 |                  |                                                                                                                                                                                                                                                                                                                                      |                                                       |                                                                                                                                                                                            | 1 | 0 | Falling edge detection |
|                 |                  | 1                                                                                                                                                                                                                                                                                                                                    | 1                                                     | Both, rising and falling edge detection                                                                                                                                                    |   |   |                        |
|                 |                  | edge detec<br>Note: The<br>puls                                                                                                                                                                                                                                                                                                      | tion.<br>e setting of l                               | erformed and capture interrupt (INTTTnCC0) is output upon<br>bits TTnIS1 and TTnIS0 are valid in the free-running mode,<br>easurement mode, encoder capture mode, and encoder<br>are mode. |   |   |                        |



### (6) TTnIOC2 - TMTn I/O control register 2

The TTnIOC2 register is an 8-bit register that controls the valid edge of external event count input (TEVTTn pin) and external trigger input (TTRGTn pin).

Access This register can be read/written in 8-bit or 1-bit units.

| Address | TT0IOC2: | FFFFF695 <sub>H</sub> |  |  |
|---------|----------|-----------------------|--|--|
|         | TT1IOC2: | FFFFF6A5 <sub>H</sub> |  |  |

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|         | 7   | 6   | 5   | 4   | 3       | 2       | 1       | 0       |
|---------|-----|-----|-----|-----|---------|---------|---------|---------|
| TTnIOC2 | 0   | 0   | 0   | 0   | TTnEES1 | TTnEES0 | TTnETS1 | TTnETS0 |
|         | R/W | R/W | R/W | R/W | R/W     | R/W     | R/W     | R/W     |

**Caution** Set the TTnIOC2 register when TTnCTL0.TTnCE = 0. When TTnCE = 1, write access to the TTnIOC2 register can be performed with the same value.

| Table 18-11 | TTnIOC2 register contents |
|-------------|---------------------------|
|-------------|---------------------------|

| Bit<br>position | Bit name           | Function     |                                                                 |                                                                                             |  |  |  |  |   |   |                                               |
|-----------------|--------------------|--------------|-----------------------------------------------------------------|---------------------------------------------------------------------------------------------|--|--|--|--|---|---|-----------------------------------------------|
| 3, 2            | TTnEES1<br>TTnEES0 | Specifies th | Specifies the external event counter input (TEVTTn) valid edge. |                                                                                             |  |  |  |  |   |   |                                               |
|                 |                    | TTnEES1      | TTnEES0                                                         | External event counter input (TEVTTn) valid edge setting                                    |  |  |  |  |   |   |                                               |
|                 |                    | 0            | 0                                                               | No edge detection (capture operation invalid)                                               |  |  |  |  |   |   |                                               |
|                 |                    | 0            | 1                                                               | Rising edge detection                                                                       |  |  |  |  |   |   |                                               |
|                 |                    | 1            | 0                                                               | Falling edge detection                                                                      |  |  |  |  |   |   |                                               |
|                 |                    | 1            | 1                                                               | Both, rising and falling edge detection                                                     |  |  |  |  |   |   |                                               |
|                 |                    |              |                                                                 | bits TTnEES1 and TTnEES0 are valid in the external event when bit TTnCTL1.TTnEEE = 1.       |  |  |  |  |   |   |                                               |
| 1, 0            | TTnETS1<br>TTnETS0 | Specifies th | e external t                                                    | rigger input (TTRGTn) valid edge.                                                           |  |  |  |  |   |   |                                               |
|                 |                    | TTnETS1      | TTnETS0                                                         | External trigger input (TTRGTn) valid edge setting                                          |  |  |  |  |   |   |                                               |
|                 |                    |              |                                                                 |                                                                                             |  |  |  |  | 0 | 0 | No edge detection (capture operation invalid) |
|                 |                    |              |                                                                 |                                                                                             |  |  |  |  | 0 | 1 | Rising edge detection                         |
|                 |                    | 1            | 0                                                               | Falling edge detection                                                                      |  |  |  |  |   |   |                                               |
|                 |                    | 1            | 1                                                               | Both, rising and falling edge detection                                                     |  |  |  |  |   |   |                                               |
|                 |                    |              | •                                                               | bits TTnETS1 and TTnETS0 are valid in the external trigger ode and the one-shot pulse mode. |  |  |  |  |   |   |                                               |



### (7) TTnIOC3 - TMTn I/O control register 3

The TTnIOC3 register is an 8-bit register that controls the valid edge of encoder clear input (TECRTn pin) and encoder input (TENCTn1 and TENCTn0 pins).

Access This register can be read/written in 8-bit or 1-bit units.

| Address | TT0IOC3: | FFFFF696 <sub>H</sub> |  |  |
|---------|----------|-----------------------|--|--|
|         | TT1IOC3: | FFFF6A6 <sub>H</sub>  |  |  |

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|         | 7      | 6      | 5      | 4      | 3       | 2       | 1       | 0       |
|---------|--------|--------|--------|--------|---------|---------|---------|---------|
| TTnIOC3 | TTnSCE | TTnZCL | TTnBCL | TTnACL | TTnECS1 | TTnECS0 | TTnEIS1 | TTnEIS0 |
|         | R/W    | R/W    | R/W    | R/W    | R/W     | R/W     | R/W     | R/W     |

**Caution** Set the TTnIOC3 register when TTnCTL0.TTnCE = 0. When TTnCE = 1, write access to the TTnIOC3 register can be performed with the same value.

#### Table 18-12 TTnIOC3 register contents (1/2)

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7               | TTnSCE   | <ul> <li>Selects the encoder counter clear method.</li> <li>0: Clear upon detection of edge of TECRTn pin</li> <li>1: Clear upon match of clear condition level</li> <li>When TTnSCE = 1, the counter is cleared to 0000H if all the conditions set with bits TTnZCL, TTnBCL, and TTnACL are matched.</li> <li>When TTnSCE = 1, the settings of bits TTnECS1 and TTnECS0 are invalid, so no encoder clear interrupt (INTTTnEC) is output.</li> <li>When TTnSCE = 0, the settings of bits TTnZCL, TTnBCL, and TTnACL are invalid. The settings of bits TTnECS1 and TTnECS0 become valid, and the</li> </ul> |
|                 |          | encoder clear interrupt (INTTTnEC) is output.<br>Caution: When TTnSCE = 1, be sure to set bits TTnUDS1, and TTnUDS0 of the TTnCTL2 register to $10_B$ or $11_B$ .                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 6               | TTnZCL   | Specifies the clear level for the Z phase of encoder input (TECRTn pin)<br>0: Clear condition = Low level<br>1: Clear condition = High level<br>Note: The TTnZCL bit is valid when TTnSCE = 1.                                                                                                                                                                                                                                                                                                                                                                                                             |
| 5               | TTnBCL   | Specifies the clear level for the B phase of encoder input (TENCTn1 pin)<br>0: Clear condition = Low level<br>1: Clear condition = High level<br>Note: The TTnBCL bit is valid when TTnSCE = 1.                                                                                                                                                                                                                                                                                                                                                                                                            |
| 4               | TTnACL   | Specifies the clear level for the Aphase of encoder input (TENCTn0 pin)<br>0: Clear condition = Low level<br>1: Clear condition = High level<br>Note: The TTnACL bit is valid when TTnSCE = 1.                                                                                                                                                                                                                                                                                                                                                                                                             |



| Bit<br>position | Bit name           |                                                                                                                                                        | Function                                                   |                                                                            |  |  |  |  |
|-----------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|----------------------------------------------------------------------------|--|--|--|--|
| 3, 2            | TTnECS1<br>TTnECS0 | Specifies th                                                                                                                                           | Specifies the encoder clear input (TECRTn pin) valid edge. |                                                                            |  |  |  |  |
|                 |                    | TTnECS1                                                                                                                                                | TTnECS0                                                    | Valid edge of encoder clear input (TECRTn pin)                             |  |  |  |  |
|                 |                    | 0                                                                                                                                                      | 0                                                          | No edge detection                                                          |  |  |  |  |
|                 |                    | 0                                                                                                                                                      | 1                                                          | Rising edge detection                                                      |  |  |  |  |
|                 |                    | 1                                                                                                                                                      | 0                                                          | Falling edge detection                                                     |  |  |  |  |
|                 |                    | 1                                                                                                                                                      | 1                                                          | Both rising and falling edge detection                                     |  |  |  |  |
|                 |                    | The encode with bits TT                                                                                                                                |                                                            | rrupt (INTTTnEC) is output upon detection of the valid edge set<br>inECS0. |  |  |  |  |
|                 |                    | Caution:                                                                                                                                               | When TTnS                                                  | SCE = 1, the encoder clear interrupt (INTTTnEC) is not output.             |  |  |  |  |
|                 |                    | <b>Note:</b> Bits TTnECS1 and TTnECS0 are valid in the encoder compare mode encoder capture mode, and encoder capture/compare mode and whe TTnSCE = 0. |                                                            |                                                                            |  |  |  |  |
| 1, 0            | TTnEIS1<br>TTnEIS0 | Specifies th                                                                                                                                           | ie encoder i                                               | input signals (TENCTn1/TENCTn0 pins) valid edge.                           |  |  |  |  |
|                 | THEIOU             | TTnEIS1                                                                                                                                                | TTnEIS0                                                    | Valid edge of the encoder input signal<br>(TENCTn1/TENCTn0 pins)           |  |  |  |  |
|                 |                    | 0                                                                                                                                                      | 0                                                          | No edge detection (capture operation invalid)                              |  |  |  |  |
|                 |                    | 0                                                                                                                                                      | 1                                                          | Rising edge detection                                                      |  |  |  |  |
|                 |                    | 1                                                                                                                                                      | 0                                                          | Falling edge detection                                                     |  |  |  |  |
|                 |                    | 1                                                                                                                                                      | 1                                                          | Both, rising and falling edge detection                                    |  |  |  |  |
|                 |                    |                                                                                                                                                        | s TTnEIS1 a<br>s or 01 <sub>B</sub> .                      | and TTnEIS0 are valid when bits TTnCTL2.TTnUDS[1:0] are                    |  |  |  |  |

### Table 18-12 TTnIOC3 register contents (2/2)



| (8)           | TTnOPT0 - TMTn option register 0 |            |                             |                          |             |            |           |        |
|---------------|----------------------------------|------------|-----------------------------|--------------------------|-------------|------------|-----------|--------|
|               |                                  | •          | ster is an 8<br>cts overflo | 3-bit registe<br>w.      | er that set | ts the cap | ture/comp | oare   |
| Access        | This regis                       | ter can be | e read/writ                 | ten in 8-bit             | or 1-bit u  | inits.     |           |        |
| Address       | TT0OPT0<br>TT1OPT0               |            |                             |                          |             |            |           |        |
| Initial Value | 00 <sub>H</sub> . This           | register i | s cleared b                 | by any rese              | et.         |            |           |        |
|               | 7                                | 6          | 5                           | 4                        | 3           | 2          | 1         | 0      |
| TTnOPT0       | 0                                | 0          | TTnCCS1                     | TTnCCS0                  | 0           | 0          | 0         | TTnOVF |
|               | R/W                              | R/W        | R/W                         | R/W                      | R/W         | R/W        | R/W       | R/W    |
|               |                                  |            |                             |                          |             |            |           |        |
| Caution       |                                  |            | •                           | en TTnCTL<br>ster can be |             |            |           |        |

### Table 18-13 TTnOPT0 register contents

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5               | TTnCCS1  | Specifies the operation mode of register TTnCCR1<br>0: Operation as compare register<br>1: Operation as capture register<br>Note: The setting of bit TTnCCS1 is valid in the free-running mode only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 4               | TTnCCS0  | Specifies the operation mode of register TTnCCR0<br>0: Operation as compare register<br>1: Operation as capture register<br>Note: The setting of bit TTnCCS0 is valid in the free-running mode only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0               | TTnOVF   | <ul> <li>Indicates TMTn overflow</li> <li>0: No overflow occurrence after timer restart or flag reset</li> <li>1: Overflow occurrence</li> <li>In the free-running mode, pulse width measurement mode, and offset trigger generation mode, if the counter value is counted up from FFFFH, overflow occurs, the TTnOVF flag is set (1), and the counter is cleared to 0000H. The counter is also cleared by writing 0. At the same time that the TTnOVF flag is set (1), an overflow interrupt (INTTTnOV) occurs.</li> <li>If 0 is written to the TTnOVF flag, or if TTnECC = 0 and TTnCE = 0 are set, the counter is cleared.</li> <li>Note: Overflow does not occur during compare match &amp; clear operation for counter value FFFFH and compare value FFFFH.</li> </ul> |
|                 |          | <ol> <li>Caution: 1. If overflow occurs in the encoder compare mode, encoder capture mode, or encoder capture compare mode, the encoder-dedicated overflow flag (TTnEOF) is set, and the overflow flag (TTnOVF) is not set. At this time, the overflow interrupt (INTTTnOV) is output.</li> <li>When TTnOVF = 1, the TTnOVF flag is not cleared even if the TTnOVF flag and TTnOPT0 register are read.</li> <li>The TTnOVF flag can be read and written, but even if 1 is written to the TTnOVF flag from the CPU, this is invalid.</li> </ol>                                                                                                                                                                                                                              |

RENESAS

| (9)           | TTnOPT1 - TMTn option register 1                                                                                             |  |  |  |  |  |  |
|---------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|               | The TTnOPT1 register is an 8-bit register that detects encoder-dedicated underflow, overflow, and counter up/down operation. |  |  |  |  |  |  |
| Access        | This register can be read/written in 8-bit or 1-bit units.                                                                   |  |  |  |  |  |  |
| Address       | TT0OPT1: FFFF698 <sub>H</sub><br>TT1OPT1: FFFF6A8 <sub>H</sub>                                                               |  |  |  |  |  |  |
| Initial Value | 00 <sub>H</sub> . This register is cleared by any reset.                                                                     |  |  |  |  |  |  |
|               | 7 0 5 4 0 0 1 0                                                                                                              |  |  |  |  |  |  |

|         | 7   | 6   | 5   | 4   | 3   | 2      | 1      | 0      |  |
|---------|-----|-----|-----|-----|-----|--------|--------|--------|--|
| TTnOPT1 | 0   | 0   | 0   | 0   | 0   | TTnEUF | TTnEOF | TTnESF |  |
|         | R/W | R/W | R/W | R/W | R/W | R/W    | R/W    | R/W    |  |

**Note** The setting of the TTnOPT1 register is valid only in the encoder compare mode, encoder capture mode, and encoder capture/compare mode. (In all other modes, the setting value is invalid.))

#### Table 18-14 TTnOPT1 register contents (1/2)

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2               | TTnEUF   | <ul> <li>Indicates encoder underflow <ul> <li>No underflow indicated</li> </ul> </li> <li>Indicates counter underflow in the encoder compare mode, encoder capture mode, and encoder capture/compare mode.</li> <li>If the counter value is counted down from 0000H, underflow occurs, the OVF flag is set (to 1), and the counter is set to FFFFH. When the TTnEUF flag is set (to 1), an overflow interrupt (INTTTnOV) occurs at the same time.</li> <li>The TTnEUF flag is cleared (to 0) under the following conditions.</li> <li>When 0 is written by CPU instruction</li> <li>When TTnCTL0.TTnCE = 0 is set while TTnCTL2.TTnECC = 0</li> </ul> Note: When TTnCTL2.TTnECC bit is 1, the flag status is held even if the value of TTnCTL0.TTnCE bit is changed from 1 to 0. Caution: 1. The TTnEUF flag is not cleared even if it is read. 2. The TTnEUF flag is not cleared even if it is read. 3. The TTnEUF flag is not cleared even if it is read. 3. The TTnEUF flag is not cleared even if it is read. |
|                 |          | <ol> <li>The TTnEUF flag can be read and written, but even if 1 is written to the<br/>TTnEUF flag, this is invalid.</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |



| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                          |
|-----------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1               | TTnEOF   | <ul> <li>Indicates encoder overflow</li> <li>0: No overflow indicated</li> <li>1: Indicates counter overflow in the encoder compare mode, encoder capture mode, and encoder capture/compare mode.</li> </ul>                                                                                                                                                      |
|                 |          | If the counter value is counted up from FFFFH, overflow occurs, the OVF flag is set (1), and the counter is cleared to 0000H. At the same time that the TTnEOF flag is set (1), an overflow interrupt (INTTTnOV) occurs.<br>However, the TTnOVF flag is not set (to 1).                                                                                           |
|                 |          | The TTnEOF flag is cleared (0) under the following conditions.                                                                                                                                                                                                                                                                                                    |
|                 |          | When 0 is written by CPU instruction                                                                                                                                                                                                                                                                                                                              |
|                 |          | <ul> <li>When TTnCTL0.TTnCE = 0 is set while TTnCTL2.TTnECC = 0</li> </ul>                                                                                                                                                                                                                                                                                        |
|                 |          | <b>Note:</b> When TTnCTL2.TTnECC bit is 1, the flag status is held even if the value of TTnCTL0.TTnCE bit is changed from 1 to 0.                                                                                                                                                                                                                                 |
|                 |          | Caution: 1. The TTnEOF flag is not cleared even if it is read.                                                                                                                                                                                                                                                                                                    |
|                 |          | <ol> <li>The TTnEOF flag can be read and written, but even if 1 is written to<br/>the TTnEOF flag from the CPU, this is invalid.</li> </ol>                                                                                                                                                                                                                       |
|                 |          |                                                                                                                                                                                                                                                                                                                                                                   |
| 0               | TTnESF   | <ul> <li>Indicates encoder count direction</li> <li>0: Indicates the up count operation of the counter in the encoder compare mode,<br/>encoder capture mode, and encoder capture/compare mode.</li> <li>1: Indicates the down count operation of the counter in the encoder compare mode,<br/>encoder capture mode, and encoder capture/compare mode.</li> </ul> |
|                 |          | The TTnESF flag is cleared (to 0) under the following conditions.                                                                                                                                                                                                                                                                                                 |
|                 |          | <ul> <li>When TTnCTL0.TTnCE = 0 is set while TTnCTL2.TTnECC = 0</li> </ul>                                                                                                                                                                                                                                                                                        |
|                 |          | <b>Note:</b> When TTnCTL2.TTnECC bit is 1, the flag status is held even if the value of TTnCTL0.TTnCE bit is changed from 1 to 0.                                                                                                                                                                                                                                 |

### Table 18-14 TTnOPT1 register contents (2/2)



### (10) TTnOPT2 - TMTn option register 2

The TTnOPT2 register is an 8-bit register that indicates the reload request status when performing write access to compare registers using the reload method.

Access This register can be read/written in 8-bit or 1-bit units.

| Address | TT0OPT1: | FFFFF699 <sub>H</sub> |
|---------|----------|-----------------------|
|         | TT1OPT1: | FFFF6A9 <sub>H</sub>  |

Initial Value 00<sub>H</sub>. This register is cleared by any reset.

|         | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0      |
|---------|-----|-----|-----|-----|-----|-----|-----|--------|
| TTnOPT2 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | TTnRSF |
|         | R/W    |

**Note** The read contents of the TTnOPT2 register are valid only in the external trigger pulse mode, PWM mode, and offset trigger generation using the reload method. In all other modes, the read contents are 0.

#### Table 18-15 TTnOPT2 register contents

| Bit<br>position | Bit name | Function                                                                                                                                                                                                                                                                                                                                         |
|-----------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2               | TTnRSF   | Indicates the reload status<br>0: No reload request, or reload completed<br>1: Reload request was output<br>This flag indicates that the data to be transferred next is held pending in the<br>TTnCCR0 and TTnCCR1 registers.<br>The TTnRSF flag is set (1) by writing to the TTnCCR1 register, and it is cleared (0)<br>upon reload completion. |
|                 |          | Caution: When TTnRSF = 1, do not perform write access to the TTnCCR0 and TTnCCR1 registers.                                                                                                                                                                                                                                                      |



### 18.5 Basic Operation

### 18.5.1 Basic counter operation

This section describes the basic operation of the counter. For details, refer to chapter "Operation in Each Mode" on page 970.

### (1) Counter start operation

# (a) Encoder compare mode, encoder capture mode, encoder capture compare mode

The count operation is controlled by the phases of pins TENCTn0 and TENCTn1.

When TTnCE = 0 and TTnECC = 0, the counter is initialized by the TTnTCW register and the count operation is started. (The setting value of the TTnTCW register is loaded to the counter at the timing when TTnCE changes from 0 to 1.)

#### (b) Triangular wave PWM MODE

The counter starts counting from initial value FFFH.

It counts up FFFFH, 0000H, 0001H, 0002H, 0003H...

Following count up operation, the counter counts down upon a match with the TTnCCR0 register.

#### (c) Modes other than the above

The counter starts counting from initial value FFFFH.

It counts up FFFFH, 0000H, 0001H, 0002H, 0003H...

### (2) Counter clear operation

There are the following five counter clear causes.

- Clear through match between counter value and compare setting value.
- Capture and clear through capture input
- Counter clear through encoder clear input (TECRTn pin)
- · Counter clear through match with clear condition level
- Clear through clear signal input (TTnSYCI) for synchronization function during slave operation

#### Table 18-16 Counter Clear Operation (1/2)

| Operation mode                     | Clear cause   |         |                                  |  |  |
|------------------------------------|---------------|---------|----------------------------------|--|--|
| operation mode                     | TTnCCR0       | TTnCCR1 | Other                            |  |  |
| Interval mode                      | Compare match | -       | -                                |  |  |
| External event count mode          | Compare match | -       | -                                |  |  |
| External trigger pulse output mode | Compare match | -       | External trigger<br>(TTRGTn pin) |  |  |
| One-shot pulse mode                | Compare match | -       | -                                |  |  |
| PWM mode                           | Compare match | -       | -                                |  |  |



### Table 18-16 Counter Clear Operation (2/2)

| Operation mode                 | Clear cause                                  |                                              |                                            |  |  |  |
|--------------------------------|----------------------------------------------|----------------------------------------------|--------------------------------------------|--|--|--|
| Operation mode                 | TTnCCR0                                      | TTnCCR1                                      | Other                                      |  |  |  |
| Free-running mode              | -                                            | -                                            | -                                          |  |  |  |
| Pulse width measurement mode   | -                                            | -                                            | External input (TITn0<br>and TITn1 pins)   |  |  |  |
| Triangular wave PWM mode       | Compare match                                | -                                            | -                                          |  |  |  |
| Encoder compare mode           | Depends on set<br>conditions <sup>Note</sup> | Depends on set<br>conditions <sup>Note</sup> | Pin TECRTn, clear<br>condition level match |  |  |  |
| Encoder capture mode           | -                                            | -                                            | Pin TECRTn, clear<br>condition level match |  |  |  |
| Encoder capture compare mode   | Depends on set conditions <sup>Note</sup>    | -                                            | Pin TECRTn, clear<br>condition level match |  |  |  |
| Offset trigger generation mode | -                                            | -                                            | External input (TITn0<br>pin)              |  |  |  |

Note Conditions are set with bits TTnECM0 and TTnECM1 of the TTnCTL2 register.

### (3) Counter reset and hold operations

In the encoder compare mode, encoder capture mode, and encoder capture/compare mode, counter value hold is controlled with bit TTnECC of the TTnCTL2 register.

If TTnCE = 0 is set when TTnECC = 0, the counter is reset to 0000H. The setting value of the TTnTCW register is loaded to the counter when TTnCE = 1 is set next.

If TTnCE = 0 is set when TTnECC = 1, the counter value is held as is. Counting resumes from the held value when TTnCE = 1 is set next.

### (4) Counter read operation during counter operation

In TMT, the counter value can be read during count operation using the TTnCNT register.



#### (5) Overflow operation

Counter overflow occurs in the free-running mode, pulse width measurement mode, encoder compare mode, encoder capture mode, encoder capture/compare mode, and offset trigger generation mode.

Overflow occurs when the counter value changes from FFFFH to 0000H.

In the free-running mode, pulse width measurement mode, offset trigger generation mode, the overflow flag (TTnOVF) is set to 1 and an overflow interrupt (INTTTnOV) is output. At this time, the TTnEOF flag is not set.

In the encoder compare mode, encoder capture mode, and encoder capture/compare mode, the encoder dedicated overflow flag (TTnEOF) is set to 1 and an overflow interrupt (INTTTnOV) occurs. At this time, the TTnOVF flag is not set.

Under the following conditions, overflow does not occur.

- When the counter value changes from initial setting FFFFH to 0000H immediately after counting start
- When FFFFH is set to the compare register, and the counter is cleared to 0000H upon a match between the counter value and the compare setting value.
- When, in the pulse width measurement mode and offset trigger generation mode, capture operation is performed for counter value FFFFH, and the counter is cleared to 0000H.

#### (6) Underflow operation

Counter underflow occurs in the triangular wave PWM Mode, encoder compare mode, encoder capture mode, and encoder capture/compare mode.

Underflow occurs when the counter value changes from 0000H to FFFFH.

When underflow occurs in the triangular wave PWM mode, an overflow interrupt (INTTTnOV) occurs. At this time, the TTnOVF flag is not set.

In the encoder compare mode, encoder capture mode, and encoder capture/compare mode, the encoder dedicated underflow flag (TTnEUF) is set to 1, and an overflow interrupt (INTTTnOV) occurs.

Underflow does not occur during count down immediately following counter start.



### (7) Description of interrupt signal operation

In TMT, the following interrupt signals are output.

| Name                     | Occurrence cause                                                                                                                            |
|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| INTTTnCC0                | <ul> <li>Match between counter and setting value of TTnCCR0 register</li> <li>Capture to TTnCCR0 register due to TITn0 pin input</li> </ul> |
| INTTTnCC1                | <ul> <li>Match between counter and setting value of TTnCCR1 register</li> <li>Capture to TTnCCR1 register due to TITn1 pin input</li> </ul> |
| INTTTnOV                 | Overflow and underflow occurrence                                                                                                           |
| INTTTnEC <sup>Note</sup> | Counter clearing through TECRTn pin                                                                                                         |

**Note** In the encoder compare mode, encoder capture mode, and encoder capture/compare mode, when TTnSCE = 0, an encoder clear interrupt (INTTTnEC) is output.



### 18.5.2 Method for writing to compare register

The TTnCCR0 and TTnCCR1 registers can be rewritten during timer operation (TTnCE = 1). There are two write modes (anytime write, reload), depending on the mode.

### (1) Anytime rewrite method

When the TTnCCR0 and TTnCCR1 registers are written during timer operation, the write value is immediately transferred to the TTnCCR0 buffer register and TTnCCR1 buffer register and is used as the value to be compared with the counter.



Figure 18-2 Basic operation flow for anytime rewrite

Note The interval mode is used as an example.





Figure 18-3 Basic anytime rewrite operation timing

- Note 1. D<sub>01</sub>, D<sub>02</sub>: Setting values of TTnCCR0 register (0000H to FFFH) D<sub>11</sub>, D<sub>12</sub>: Setting values of TTnCCR1 register (0000H to FFFFH)
  - 2. The interval mode is used as an example.



#### (2) Reload method (Batch rewrite)

When TTnCCR0, TTnCCR1 register write is performed during timer operation, the written value is used as the comparison value for the counter via the TTnCCR0 and TTnCCR1 buffer registers.

Under the reload method, rewrite the TTnCCR0 register before the TTnCCR0 register value is matched, and next, write to the TTnCCR1 register.

Then, when the TTnCCR0 register is matched or the counter is cleared to 0000H through external input, the values of the TTnCCR0 register and TTnCCR1 register are reloaded.

By writing to the TTnCCR1 register, the value becomes valid at the next reload timing.

Therefore, even if wishing to rewrite only the value of the TTnCCR0, rewrite the same value to the TTnCCR1 register to make the next reload valid.



Figure 18-4 Basic operation flow for reload (batch rewrite)

**Caution** Rewrite to the TTnCCR1 register includes enabling reload. Therefore, rewrite the TTnCCR1 register after rewriting the TTnCCR0 register.

Note The PWM mode is used as an example.





Figure 18-5 Basic reload operation timing

- **Note 1.** Since the TTnCCR1 register is not written to, reloading is not performed even if TTnCCR0 is rewritten.
  - 2. D<sub>01</sub>, D<sub>02</sub>, D<sub>03</sub>: Setting values of TTnCCR0 register (0000H to FFFH) D<sub>11</sub>, D<sub>12</sub>: Setting values of TTnCCR1 register (0000H to FFFFH)
  - 3. The PWM mode is used as an example.

 Table 18-17
 Capture/compare rewrite methods in each mode

| Operation mode                     | Capture/compare rewrite method                                               |                            |
|------------------------------------|------------------------------------------------------------------------------|----------------------------|
|                                    | TTnCCR0                                                                      | TTnCCR1                    |
| Interval mode                      | Compare only (Anytime write type)                                            |                            |
| External event count mode          |                                                                              |                            |
| External trigger pulse output mode | Compare only (Reload type)                                                   |                            |
| One-shot pulse mode                | Compare only (Anytime write type)                                            |                            |
| PWM mode                           | Compare only (Reload type)                                                   |                            |
| Free-running mode                  | Capture/compare selectable<br>(When compare is selected, anytime write type) |                            |
| Pulse width measurement mode       | Capture only                                                                 |                            |
| Triangular wave PWM mode           | Compare only (Reload type)                                                   |                            |
| Encoder compare mode               | Compare only (Anytime write type)                                            |                            |
| Encoder capture mode               | Capture only                                                                 |                            |
| Encoder capture compare mode       | Compare only (Anytime write type)                                            | Capture only               |
| Offset trigger generation mode     | Capture only                                                                 | Compare only (Reload type) |



### 18.6 Operation in Each Mode

### 18.6.1 Interval timer mode

In the interval timer mode, a compare match interrupt (INTTTnCC0) occurs and the counter is cleared upon a match between the setting value of the TTnCCR0 register and the counter value. The

occurrence interval for this counter and TTnCCR0 register match interrupt becomes the interval time.

In the interval timer mode, the counter is cleared only upon a match between the counter and the value of the TTnCCR0 register. Counter clearing using the TTnCCR1 register is not performed.

However, the setting value of the TTnCCR1 is compared to the counter value transferred to the TTnCCR1 buffer register and a compare match interrupt (INTTTnCC1) is output.

The TTnCCR0 and TTnCCR1 registers can be rewritten using the anytime write method, regardless of the value of bit TTnCE.

Pins TOTn0 and TOTn1 are toggle output controlled when bits TTnOE0 and TTnOE1 are set to 1.



Figure 18-6 Basic operation flow in interval timer mode

**Note** In the case of a match between the counter and TTnCCR1 register, the counter is not cleared.





Figure 18-7 Basic timing in interval timer mode (1/2) When D1>D2>D3, only value of TTnCCR0 register is rewritten, TOTn0 and TOTn1 are not output (TTnOE0, 1 = 0, TTnOL0 = 0, TTnOL1 = 1)

- Note 1. D1, D2: Setting values of TTnCCR0 register (0000H to FFFFH) D3: Setting values of TTnCCR1 register (0000H to FFFFH)
  - 2. Interval time =  $(Dm + 1) \times (count clock cycle)$
  - 3. m = 1 to 3





Figure 18-8 Basic timing in interval timer mode (2/2) When D1 = D2, values of TTnCCR0 and TTnCCR1 registers not rewritten, TOTn1 output performed (TTnOE0, 1 = 1, TTnOL0 = 0, TTnOL1 = 1)

- Note 1. D1: Setting value of TTnCCR0 register (0000H to FFFFH) D2: Setting value of TTnCCR1 register (0000H to FFFFH)
  - 2. Interval time =  $(Dm + 1) \times (count clock cycle)$
  - 3. TOTn0, TOTn1 toggle time =  $(Dm + 1) \times (count clock cycle)$
  - 4. m = 1, 2



### 18.6.2 External event count mode

In the external event count mode, count up starts upon external event input (TEVTTn pin). (The external event input (TEVTTn) is used as the count clock, regardless of bit TTnEEE of the TTnCTL1 register.)

In the external event count mode, the counter is cleared only upon a match between the counter and the value of the TTnCCR0 register. Counter clearing using the TTnCCR1 register does not work.

However, the value of the TTnCCR1 register is transferred to the TTnCCR1 buffer register, compared to the counter value, and a compare match interrupt (INTTTnCC1) is output.

The TTnCCR0 and TTnCCR1 registers can be rewritten with the anytime write method, regardless of the value of bit TTnCE.

Pins TOTn0 and TOTn1 are toggle output controlled when bits TTnOE0 and TTnOE1 are set to 1.

When using only one compare register channel, it is recommended to set the TTnCCR1 register to FFFFH.

[External event count operation flow]

- <1> TTnCTL1 register bits TTnMD3 to TTnMD0 = 0001B (mode setting) Edge detection set with TTnIOC2 register bits TTnEES1 and TTnEES0 (TTnEES1, TTnEES0 = setting other than 01B)
- <2> TTnCTL0 register bit TTnCE = 1 (count enable)
- <3> TEVTTn pin input edge detection (count-up start)
- Caution 1. In external event count mode, when the setting value of the TTnCCR0 register is set to m, the number of TEVTTn pin input edge detection times is m+1.
  - 2. In external event count mode, do not send the TTnCCR0 register to 0000H.





- Figure 18-9 Basic operation timing in external event count mode (1/4) When D1>D2>D3, only value of TTnCCR0 register is rewritten, TOTn0 and TOTn1 are not output. The signal input from TEVTTn and internally synchronized is counted as the count clock (TTnOE0, 1 = 0, TTnOL0 = 0, TTnOL1 = 1)
  - Note 1. D1, D2: Setting values of TTnCCR0 register (0000H to FFFFH) D3: Setting value of TTnCCR1 register (0000H to FFFFH)
    - 2. Number of event counts = (Dm + 1) (m = 1, 2)





#### Figure 18-10

 Operation timing in external event count mode (2/4)
 When D1 = D2, TTnCCR0 and TTnCCR1 register values are not rewritten, TOTn0 and TOTn1 are output (TTnOE0, 1 = 1, TTnOL0 = 0, TTnOL1 = 1)

- Note 1. D1: Setting value of TTnCCR0 register (0000H to FFFFH) D2: Setting value of TTnCCR1 register (0000H to FFFFH)
  - 2. Number of event counts = (Dm + 1) (m = 1, 2)





- Figure 18-11 Operation timing in external event count mode (3/4) When D1 = D2, TTnCCR0 and TTnCCR1 register values are not rewritten, TOTn0 and TOTn1 are output (TTnOE0, 1 = 1, TTnOL0 = 0, TTnOL1 = 1)
  - Note 1. D1: Setting value of TTnCCR0 register (0000H) D2: Setting value of TTnCCR1 register (0000H)
    - **2.** Number of event counts = (Dm + 1) (m = 1, 2)





- Figure 18-12 Basic operation timing in external event count mode (4/4) When D1 = D2, TTnCCR0, TTnCCR1 register values are not rewritten, TOTn0 and TOTn1 are output (TTnOE0, 1 = 1, TTnOL0 = 0, TTnOL1 = 1)
  - Note 1. D1: Setting value of TTnCCR0 register (0001H) D2: Setting value of TTnCCR1 register (0000H)
    - 2. Number of event counts = (Dm + 1) (m = 1, 2)



## 18.6.3 External trigger pulse output mode

When, in the external trigger pulse mode, the duty is set to the TTnCCR1 register, the cycle is set to the TTnCCR0 register, and TTnCE = 1 is set, external trigger input (TTRGTn pin) wait results, with the counter remaining stopped at FFFFH. Upon detection of the valid edge of external trigger input (TTRGTn pin), or when the TTnEST bit of the TTnCTL1 register is set, count up starts.

An external trigger pulse is output from pin TOTn1, and toggle output is performed from pin TOTn0 upon a match with the TTnCCR0 register. Moreover, during the count operation, upon a match between the counter and the TTnCCR0 register, a compare match interrupt (INTTTnCC0) is output, and upon a match between the counter and TTnCCR1 register, a compare match interrupt (INTTTnCC1) is output.

The TTnCCR0 and TTnCCR1 registers can be rewritten during count operation. Compare register reload is performed at the timing when the counter value and the TTnCCR0 register match.

However, when write access to the TTnCCR1 register is performed, the next reload timing becomes valid, so that even if wishing to rewrite only the value of the TTnCCR0 register, write the same value to the TTnCCR1 register. In this case, reload is not performed even if only the TTnCCR0 register is rewritten.

If, during operation in the external trigger pulse output mode, the external trigger (TTRGTn pin) edge is detected several times, or if the TTnEST bit of the TTnCTL1 register is set (to 1), the counter is cleared and count up is resumed.

Moreover, if at this time, the TOTn1 pin is in the low level status, the TOTn1 pin output becomes high level when an external trigger is input. If the TOTn1 pin is in the high level status, it remains high level even if external trigger input occurs.

In the external trigger pulse output mode, the TTnCCR0 and TTnCCR1 registers have their function fixed as compare registers, so the capture function cannot be used.

Caution In the external trigger pulse mode, set bit TTnEEE of the TTnCTL1 register to 0.





- Figure 18-13 Basic operation flow in external trigger pulse output mode
  - **Note** The counter is not cleared upon a match between the counter and the TTnCCR1 buffer register.





- Figure 18-14 Basic operation timing in external trigger pulse output mode When values of TTnCCR0 and TTnCCR1 registers are rewritten, TOTn0 and TOTn1 are output (TTnOE0, 1 = 1, TTnOL0, 1 = 0)
  - Note 1. D<sub>01</sub>, D<sub>02</sub>: Setting values of TTnCCR0 register (0000H to FFFFH) D<sub>11</sub>, D<sub>12</sub>: Setting values of TTnCCR1 register (0000H to FFFFH)
    - TOTn1 (PWM) duty = (setting value of TTnCCR1 register) × (count clock cycle) TOTn1 (PWM) cycle = (setting value of TTnCCR0 register + 1) × (count clock cycle)
    - **3.** Pin TOTn0 is toggled when the counter is cleared immediately following count start.



### 18.6.4 One-shot pulse mode

When, in the one-shot pulse mode, the duty is set to the TTnCCR0 register, the output duty delay value is set to the TTnCCR1 register, and bit TTnCE of the TTnCTL0 register is set to 1, external trigger input (TTRGTn pin) wait results, with the counter remaining stopped at FFFFH. Upon detection of the valid edge of external trigger input (TTRGTn pin), or when bit TTnEST of the TTnCTL0 register is set to 1, count up starts. The TOTn1 pin becomes high level upon a match between the counter and TTnCCR1 register. Moreover, upon a match between the counter and TTnCCR0 register, the TOTn1 pin becomes low level, and the counter is cleared to 0000H and then stops. The TOTn0 pin performs toggle output during the count operation upon a match between the counter and the TTnCCR0 buffer register. Moreover, upon a match between the counter and TTnCCR0 register during count operation, a compare match interrupt (INTTTnCC0) is output, and upon a match between the counter and TTnCCR1 buffer register, a compare match interrupt (INTTTnCC1) is output.

The TTnCCR0 and TTnCCR1 registers can be rewritten using the anytime write method, regardless of the value of bit TTnCE.

Even if a trigger is input during the counter operation, it is ignored. Be sure to input the second trigger when the counter is stopped at 0000H.

In the one-shot pulse mode, registers TTnCCR0 and TTnCCR1 have their function fixed as compare registers, so the capture function cannot be used.

[One-shot pulse operation flow]

- <1> TTnCTL1 register bits TTnMD3 to TTnMD0 = 0011B (One-shot pulse mode)
- <2> TTnCCR0 register setting (duty setting), TTnIOC0 register bit TTnOE1 = 1 (TOTn1 pin output enable)
- <3> TTnCTL0 register bit TTnCE = 1 (counter operation enable): TOTn1 = Low-level output
- <4> TTnCTL1 register bit TTnEST = 1 or TTRGTn pin edge detection (count-up start):
  - TOTn1 = Low-level output
- <5> Match between counter value and TTnCCR1 buffer register: TOTn1 = High-level output
- <6> Match between counter value and TTnCCR0 buffer register: TOTn1 = Low-level output, count clear
- <7> Count stop: TOTn1 = Low-level output
- <8> TTnCE = 0 (operation reset)

<1> to <2> can be in any order.

Caution In the one-shot pulse mode, set bit TTnEEE of the TTnCTL1 register to 0.







- Figure 18-15 Basic operation flow in one-shot pulse mode
  - Note The counter is not cleared upon a match between the counter and the TTnCCR1 buffer register.
  - **Caution** The counter is not cleared even if trigger input is realized while the counter counts up, and the trigger input is ignored.





Figure 18-16 Basic operation timing in one-shot pulse mode (TTnOE0, 1 = 1, TTnOL0, 1 = 0)

- Note 1. Count up starts when the value of TTnEST becomes 1 or TTRGTn is input.
  - D0: Setting value of TTnCCR0 register (0000H to FFFFH) D1: Setting value of TTnCCR1 register (0000H to FFFFH)
  - TOTn1 (output delay) = (setting value of TTnCCR1 register) × (count clock cycle) TOTn1 (output pulse width) = {(setting value of TTnCCR0 register +1) (setting value of TTnCCR1 register)} × (count clock cycle)



# 18.6.5 PWM mode

When, in the PWM mode, the duty is set to the TTnCCR1 register, the cycle is set to the TTnCCR0 register, and TTnCE = 1 is set, variable duty PWM output is performed from pin TOTn1.

Simultaneously with the start of count up operation, pin TOTn1 becomes active level, and upon a match between the counter and the TTnCCR1 register, becomes inactive level. Next, the TOTn1 pin becomes active level upon a match with the TTnCCR0 register. The TOTn0 pin performs toggle output upon a match with the TTnCCR0 buffer register.

During count operation, a compare match interrupt (INTTTnCC0) is output upon a match between the counter and TTnCCR0 register, and a compare match interrupt (INTTTnCC1) is output upon a match between the counter and TTnCCR1 register.

The TTnCCR0 and TTnCCR1 registers can be rewritten during count operation. Compare register reload occurs upon a match between the counter value and the TTnCCR0 buffer register. However, since the next reload timing becomes valid when the TTnCCR1 register is written to, write the same value to the TTnCCR1 register even when wishing to rewrite only the value of the TTnCCR0 register. Reloading is not performed if only the TTnCCR0 register is rewritten.

In the PWM mode, the TTnCCR0 and TTnCCR1 registers have their function fixed as compare registers, so the capture function cannot be used.



#### Figure 18-17 Basic operation mode in PWM mode (1/2) When values of TTnCCR0 and TTnCCR1 registers are not rewritten during timer operation



- Figure 18-18 Basic operation flow in PWM mode (2/2) When values of TTnCCR0 and TTnCCR1 registers are rewritten during timer operation
  - Note Regarding the sequence, the timing of <2> may differ depending on the <1> or <3> rewrite timing, the value of the TTnCCR1 register, etc., but of <1> and <3>, always make <3> the last.





- Figure 18-19 Basic operation timing in PWM mode (1/2) When only value of TTnCCR1 is rewritten, and TOTn0 and TOTn1 are output (TTnOE0, 1 = 1, TTnOL0, 1 = 0)
  - Note 1. D<sub>00</sub>: Setting value of TTnCCR0 register (0000H to FFFH) D<sub>10</sub>, D<sub>11</sub>, D<sub>12</sub>, D<sub>13</sub>: Setting values of TTnCCR1 register (0000H to FFFH)
    - TOTn1 (PWM) duty = (setting value of TTnCCR1 register) × (count clock cycle)
      - TOTn1 (PWM) cycle = (setting value of TTnCCR0 register + 1)  $\times$  (count clock cycle)
    - 3. TOTn0 is toggled immediately following counter start and at (setting value of TTnCCR0 register + 1) × (count clock cycle)





Figure 18-20 Basic operation timing in PWM mode (2/2) When values of TTnCCR0 and TTnCCR1 register are rewritten, TOTn0 and TOTn1 are output (TTnOE0, 1 = 1, TTnOL0, 1 = 0)

- **Note 1.** The TTnCCR1 register was not written to, so transfer to the TTnCCR0 buffer register was not performed. Held until the next reload timing.
  - D<sub>00</sub>, D<sub>01</sub>, D<sub>02</sub>, D<sub>03</sub>: Setting values of TTnCCR0 register (0000H to FFFH) D<sub>10</sub>, D<sub>11</sub>, D<sub>12</sub>, D<sub>13</sub>: Setting values of TTnCCR1 register (0000H to FFFFH)
  - 3. The TOTn0 and TOTn1 pins become high level at timer count start.



# 18.6.6 Free-running mode

The operation flow in free-running mode depends on the setting of the TTnOPT0.TTnCCS[1:0] bits, and is shown below.



Figure 18-21 Basic operation flow in free-running mode



# (1) Compare function (TTnCCS1 = 0, TTnCCS0 = 0)

When TTnCTL0 register bit TTnCE is set to 1, the counter counts from 0000H to FFFFH. An overflow interrupt (INTTTnOV) is output when the counter value changes from FFFFH to 0000H, and the counter is cleared. The count operation is performed in the free-running mode until TTnCE = 0 is set. Moreover, during count operation, a compare match interrupt (INTTTnCC0) is output upon a match between the counter and TTnCCR0 buffer register, and a compare match interrupt (INTTTnCC1) is output upon a match between the counter and TTnCCR0 buffer register.

The TTnCCR0 and TTnCCR1 registers can be rewritten using the anytime write method, regardless of the value of the TTnCE bit.

The TOTn0 and TOTn1 pins are toggle output controlled when bits register TTnOE0 and TTnOE1 of the TTnIOC0 register are set to 1.



Figure 18-22 Basic operation timing in free-running mode (compare function) When values of TTnCCR0 and TTnCCR1 registers are rewritten, TOTn0, TOTn1 are output (TTnOE0, 1 = 1, TTnOL0, 1 = 0)

| Note | 1. | Doo, Do1: Setting values of TTnCCR0 register (0000H to FFFFH)                          |
|------|----|----------------------------------------------------------------------------------------|
|      |    | D <sub>10</sub> , D <sub>11</sub> : Setting values of TTnCCR1 register (0000H to FFFH) |

- 2. TOTn0 (toggle) width = (setting value of TTnCCR0 register + 1) × (count clock cycle)
- 3. TOTn1 (toggle) width = (setting value of TTnCCR1 register + 1) × (count clock cycle)
- 4. Pins TOTn0 and TOTn1 become high level at count start.



# (2) Capture function (TTnCCS1 = 1, TTnCCS0 = 1)

When TTnCTL0 register bit TTnCE is set to 1, the counter counts from 0000H to FFFFH. An overflow interrupt (INTTTnOV) is output when the value of the counter changes from FFFFH to 0000H, and the counter is cleared. The count operation is performed in the free-running mode until TTnCE = 0 is set. When, during count operation, the counter value is captured to the TTnCCR0 and TTnCCR1 registers through detection of the valid edge of capture input (TITn1, TITn0), a capture interrupt (INTTTnCC0, INTTTnCC1) is output.

Regarding capture in the vicinity of overflow (FFFFH), judgment is possible with the overflow flag (TTnOVF). However, judgment with the TTnOVF flag is not possible when the capture trigger interval is such that it includes two overflow occurrences (2 or more free-running cycles).



Figure 18-23 Basic operation timing in free-running mode (capture function) When TOTn0, TOTn1 are not output (TTnOE0, 1 = 0, TTnOL0, 1 = 0)

- Note 1. D<sub>00</sub>, D<sub>01</sub>: Values captured to TTnCCR0 register (0000H to FFFH) D<sub>10</sub>, D<sub>11</sub>: Values captured to TTnCCR1 register (0000H to FFFH)
  - TITn0: Setting to rising edge detection (TTnIOC1 register bits TTnIS1, TTnIS0 = 01) TITn1: Setting to falling edge detection (TTnIOC1 register bits TTnIS3, TTnIS2 = 10)



# (3) Compare/capture function (TTnCCS1 = 0, TTnCCS0 = 1)

When TTnCTL0 register bit TTnCE is set to 1, the counter counts from 0000H to FFFFH, an overflow interrupt (INTTTnOV) is output when the value of the counter changes from FFFFH to 0000H, and the counter is cleared. The count operation is performed in the free-running mode until TTnCE = 0 is set. The TTnCCR1 register is used as a compare register, and as the interval function upon a match between the counter and TTnCCR1 register, a compare match interrupt (INTTTnC1) is output. Since the TTnCCR0 register is set to the capture function, the TOTn0 pin cannot be controlled even when TTnIOC0 register bit TTnOE0 is set to 1.



Figure 18-24 Basic operation timing in free-running mode (compare/capture function) When value of TTnCCR1 is rewritten, TOTn0, TOTn1 are output (TTnOE0, 1 = 1, TTnOL0, 1 = 0)

- Note 1. D<sub>00</sub>, D<sub>01</sub>: Setting values of TTnCCR1 register (0000H to FFFFH) D<sub>10</sub>, D<sub>11</sub>, D<sub>12</sub>, D<sub>13</sub>, D<sub>14</sub>, D<sub>15</sub>: Values captured to TTnCCR0 register (0000H to FFFFH)
  - TITn0: Setting to rising edge detection (TTnIOC1 register bits TtnIS1, TtnIS0 = 11)

## (4) Overflow flag

When, in the free-running mode, the counter overflows from FFFFH to 0000H, the overflow flag (TTnOVF) is set to "1", and an overflow interrupt (INTTTnOV) is output.

The overflow flag is cleared through 0 write from the CPU.

(The overflow flag is not cleared by just being read.)

## 18.6.7 Pulse width measurement mode

In the pulse width measurement mode, counting is performed in the freerunning mode. The counter value is saved to the TTnCCR0 register, and the counter is cleared to 0000H. As a result, the external input pulse width can be measured. However, when measuring a long pulse width that exceeds counter overflow, perform judgment with the overflow flag. Measurement of pulses during which overflow occurs twice or more is not possible, so adjust the counter's operating frequency. Even in the case of TITn1 pin edge detection, pulse width measurement can be similarly performed by using the TTnCCR1 register.





- Note 1. Doo, Do1, Do2, Do3: Values captured to TTnCCR0 register (0000H to FFFH)
  - 2. TITn0: Setting to rising edge/falling edge (both edges) detection (TTnIOC1 register bits TtnIS1, TtnIS0 = 11)

# 18.6.8 Triangular wave PWM mode

In the triangular wave PWM mode, similarly to in the PWM mode, when the duty is set to the TTnCCR1 register, the cycle is set to the TTnCCR0 register, and TTnCE = 1 is set, variable duty and cycle type triangular wave PWM output is performed from pin TOTn1. The TOTn0 pin is toggle output upon a match with the TTnCCR0 buffer register and upon counter underflow. Upon a match between the counter and TTnCCR0 register during count operation, a compare match interrupt (INTTTnCC0) is output, and upon a match between the counter underflow, an overflow interrupt (INTTTnCC1) is output.

The TTnCCR0 and TTnCCR1 registers can be rewritten during count operation. Compare register reload occurs upon a match between the counter value and the TTnCCR0 buffer register. However, since the next reload timing becomes valid when the TTnCCR1 register is written to, write the same value to the TTnCCR1 register even when wishing to rewrite only the value of the TTnCCR0 register. Reloading is not performed if only the TTnCCR0 register is rewritten. The reload timing is the underflow timing.

In the triangular wave PWM mode, the TTnCCR0 and TTnCCR1 registers have their function fixed as compare registers, so the capture function cannot be used.

Note In the triangular wave PWM mode, set the TTnCCR0 register to a value of 0  $\leq$  TTnCCR0  $\leq$  FFFEH.



Figure 18-26 Basic operation timing in triangular wave pwm mode When TOTn0, TOTn1 are output (TTnOE0, 1 = 1, TTnOL0, 1 = 0)

# 18.6.9 Encoder count function

Three encoder count function modes are provided, one for each capture compare function.

| Mode                         | TTnCCR0 register | TTnCCR1 register |
|------------------------------|------------------|------------------|
| Encoder compare mode         | Compare only     | Compare only     |
| Encoder capture mode         | Capture only     | Capture only     |
| Encoder capture compare mode | Compare only     | Capture only     |

### (1) Counter up/down control

Counter up/down control is performed and the counter is operated according to the phase of signals TENCTn0 and TENCTn1 from the encoder and the set conditions of bits TTnUDS1 and TTnUDS0 of the TTnCTL2 register.

### (2) Basic operation

To use the TTnCCR0 and TTnCCR1 registers are compare-only registers, enable rewrite during timer operation.

The rewrite method is anytime write.

A compare match interrupt (INTTTnCC0) is output upon a match between the counter and TTnCCR0 register. A compare match interrupt (INTTTnCC1) is output upon a match between the counter and TTnCCR1 register.

To use the TTnCCR0 and TTnCCR1 registers are capture-only registers, save the counter value to the capture registers (TTnCCR0, TTnCCR1) through detection of the edges of pins TITn0 and TITn1. Specification of the detection of the edges of pins TITn0 and TITn1 is done with bits TTnIS3 to TTnIS0 of the TTnIOC1 register. Pin TOTn0 outputs the count status.

If the TTnCCR1 register is a compare-only register, pin TOTn1 is toggled upon a match between the counter and the TTnCCR1 register.

If the TTnCCR1 register is a capture-only register, pin TOTn1 becomes the level set with bit TTnOL1 of the TTnIOC0 register.

If TTnOL1 = 0, pin TOTn1 outputs a low level, and if TTnOL1 = 1, pin TOTn1 outputs a high level.

## (3) Counter clear operation

Clearing of the counter to 0000H is performed under the following conditions in each mode.

| Clear condition                                                                                                                 | Encoder<br>compare | Encoder<br>capture | Encoder<br>capture<br>compare   |
|---------------------------------------------------------------------------------------------------------------------------------|--------------------|--------------------|---------------------------------|
| Method whereby counter is cleared to 0000H upon match with compare register (setting of TTnCTL2 register bits TTnECM1, TTnECM0) | $\checkmark$       | -                  | √<br>(TTnECM0 <sup>Note</sup> ) |



| Clear condition                                                                                                                                                        | Encoder<br>compare | Encoder<br>capture | Encoder<br>capture<br>compare |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|--------------------|-------------------------------|
| Method whereby counter is cleared to 0000H upon detection of edge of pin TECR0 (setting of bits TTnECS1, TTnECS0 when TTnIOC3 register bit TTnSCE = 0)                 | $\checkmark$       | $\checkmark$       | $\checkmark$                  |
| Method whereby counter is cleared to 0000H by special clear<br>function of encoder<br>(setting of bits TTnZCL, TTnBCL, TTnACL when TTnIOC3<br>register bit TTnSCE = 1) | V                  | V                  | $\checkmark$                  |

**Note** Since the TTnCCR1 register is a capture-only register, the setting of TTnCTL2 register bit TTnECM1 are invalid.



### (4) Control through TTnCTL2 register

The settings of the TTnCTL2 register in the encoder compare mode, encoder capture mode, and encoder capture/compare mode (TTnMD3 to TTnMD0 = 1000B, 1001B, 1010B) are as follows.

| TTnMD3 to 0 | TTnUDS1 to 0                                         | TTnECM1 | TTnECM0 | TTnLDE  | Clear   | Load |   |  |   |   |  |  |
|-------------|------------------------------------------------------|---------|---------|---------|---------|------|---|--|---|---|--|--|
|             |                                                      | 0       | 0       | 0       | _       | _    |   |  |   |   |  |  |
|             |                                                      |         | U       | 1       | _       |      |   |  |   |   |  |  |
|             |                                                      | 0       | 1       | 0       | TTnCCR0 | _    |   |  |   |   |  |  |
| 1000B       |                                                      |         | I       | 1       | THECHU  | •    |   |  |   |   |  |  |
|             | All                                                  |         | 0       | Invalid | TTnCCR1 | _    |   |  |   |   |  |  |
|             | All settings<br>possible<br>00B<br>01B<br>10B<br>11B | 1       | 1       | Invalid | TTnCCR0 | _    |   |  |   |   |  |  |
|             |                                                      |         |         |         | TTnCCR1 |      |   |  |   |   |  |  |
| 1001B       |                                                      |         | Invalid |         | —       | _    |   |  |   |   |  |  |
|             |                                                      | 0       | 0       | 0       | _       | _    |   |  |   |   |  |  |
|             |                                                      |         | 0       | 0       | 0       | 0    | 0 |  | 1 | 1 |  |  |
| 1010B       |                                                      |         | 1       | 0       | TTnCCR0 | -    |   |  |   |   |  |  |
| 10108       |                                                      |         |         | 1       | THECHO  | •    |   |  |   |   |  |  |
|             |                                                      | 4       | 0       | Invalid | -       | -    |   |  |   |   |  |  |
|             |                                                      | 1       | 1       | Invalid | TTnCCR0 | -    |   |  |   |   |  |  |

- In the case of bits TTnUDS1 and TTnUDS0, up/down judgment control is performed for the phase input from pins TENCTn0 and TENCTn1.
- In the case of bits TTnECM1 and TTnECM0, counter clear control is performed upon a match between the counter value and the compare setting value.

Bits TTnECM1 and TTnECM0 are valid in modes where the TTnCCR0 or TTnCCR1 register is used as a compare-only register. These bits are invalid in modes where the TTnCCR0 or TTnCCR1 register is used as a capture-only register.

• The TTnLDE bit controls the function to load to the counter the setting value of the TTnCCR0 register upon occurrence of counter underflow. Bit TTnLDE is valid only when the TTnECm bit setting is 00B, 01B, in a mode where the TTnCCR0 or TTnCCR1 register is used as a compare-only register.

In the case of all other settings, bit TTnLDE is invalid even if manipulated.

As an example of the use of the encoder count function, counter operation becomes possible between the setting values of registers 0000H to TTnCCR0 by using the counter load functions (TTnLDE = 1) indicated with "•" in the table, and the function for clearing the counter to 0000H in case the count operation following a match with the TTnCCR0 buffer register is up count (TTnECM0 = 1). (Refer to "Counter load function for TTnCCR0 register setting value upon underflow (bit TTnLDE of register TTnCTL2))" on page 1004).



# (a) Up/down count selection specification (TTnCTL2 register bits TTnUDS1, TTnUDS0)

Counter up/down is judged according to the settings of bits TTnUDS1 and TTnUDS0, and the phases input from pins TENCTn0 and TENCTn1.

Bits TTnUDS1 and TTnUDS0 are valid only in the encoder compare mode, encoder capture mode, and encoder capture/compare mode.

1. TTnCTL2: TTnUDS1, 0 = 00B (count judgment mode 1)

| A phase (pin TENCTn0) | B phase (pin TENCTn1) | Count |
|-----------------------|-----------------------|-------|
| Rising edge           |                       |       |
| Falling edge          | High level            | Down  |
| Both edges            |                       |       |
| Rising edge           |                       |       |
| Falling edge          | Low level             | Up    |
| Both edges            |                       |       |

Operation example:

| TTnIOC3:<br>TTnEIS3 to 2       | TENCTn1 pin input | Edge detection specification invalid |
|--------------------------------|-------------------|--------------------------------------|
| TTnIOC3:<br>TTnEIS1 to 0 = 10B | TENCTn0 pin input | Rising edge detection                |



- Figure 18-27 Encoder count function up/down count selection specification timings (1/6) timing 1
  - **Note** Counting is performed when the edges of the TENCTn0/TENCTn1 pin inputs overlap.
    - 2. TTnCTL2: TTnUDS1, 0 = 01B (count judgment mode 2)



| A phase (pin TENCTn0) | B phase (pin TENCTn1) | Count |
|-----------------------|-----------------------|-------|
| Low level             | Rising edge           |       |
|                       | Falling edge          |       |
|                       | Both edges            | Down  |
| High level            | Rising edge           | Down  |
|                       | Falling edge          |       |
|                       | Both edges            |       |
| Rising edge           |                       |       |
| Falling edge          | Low level             |       |
| Both edges            |                       | Up    |
| Rising edge           |                       | Ορ    |
| Falling edge          | High level            |       |
| Both edges            |                       |       |
| Simultaneous pin TEN  | CTn0/TENCTn1 inputs   | Hold  |

Operation example:

TTnIOC3: TTnEIS3, TENCTn1 pin input Rising edge detection 2 = 10BTTnIOC3: TTnEIS1, TENCTn0 pin input Rising edge detection 0 = 10B



- Figure 18-28 Encoder count function up/down count selection specification timings (2/6) timing 2
  - **Note** The count value is held when the edges of the TENCTn0/TENCTn1 pin inputs overlap.

3. TTnCTL2: TTnUDS1, 0 = 10B (count judgment mode 3)



| A phase<br>(pin TENCTn0) | B phase<br>(pin TENCTn1) | Count |  |
|--------------------------|--------------------------|-------|--|
| Low level                | Falling edge             | Hold  |  |
| Rising edge              | Low level                | Down  |  |
| High level               | Rising edge              |       |  |
| Falling edge             | High level               | Hold  |  |
| Rising edge              | High level               | TIOIQ |  |
| High level               | Falling edge             | 1     |  |
| Falling edge             | Low level                | Up    |  |
| Low level                | Rising edge              | Hold  |  |
| Rising edge              | Rising edge              | Hold  |  |
| Falling edge             | Rising edge              | ΠΟΙϤ  |  |
| Rising edge              | Falling edge             | Down  |  |
| Falling edge             | Falling edge             | Up    |  |

Operation example:

TTnIOC3: TTnEIS3 to 0 Pins TENCTn1, TENCTn0 Edge detection specification invalid



Figure 18-29 Encoder count function up/down count selection specification timings (3/6) - timing 3

# 4. TTnCTL2: TTnUDS1, 0 = 11B (count judgment mode 4)

| A phase<br>(pin TENCTn0) | B phase<br>(pin TENCTn1) | Count |  |
|--------------------------|--------------------------|-------|--|
| Low level                | Falling edge             |       |  |
| Rising edge              | Low level                | Down  |  |
| High level               | Rising edge              | DOWN  |  |
| Falling edge             | High level               |       |  |
| Rising edge              | High level               |       |  |
| High level               | Falling edge             | Up    |  |
| Falling edge             | Low level                | Οp    |  |
| Low level                | Rising edge              |       |  |
| Simultaneous pin TEN     | Hold                     |       |  |





Figure 18-30 Encoder count function up/down count selection specification timings (4/6) - timing 4





Figure 18-31 Encoder count function up/down count selection specification timings (5/6) - timing 5



**Note** The count value is held when the edges of the TENCTn0/TENCTn1 pin inputs overlap.

#### (b) Counter clear condition setting upon match between counter value and compare setting value (TTnCTL2 register bits TTnECM1, TTnECM0)

Counter operation is performed according to the setting values of these bits upon a match between the counter value and the compare setting value.

1. TTnECM1, 0 = 00B

Counter clear is not performed upon a match between the counter and compare values.

2. TTnECM1, 0 = 01B

Counter clear is performed upon a match between the counter and the TTnCCR0 register.

| Next count operation | Description                   |
|----------------------|-------------------------------|
| Up count             | Clear counter to 0000H.       |
| Down count           | Down count the counter value. |

#### 3. TTnECM1, 0 = 10B

Operation is performed under the following conditions upon a match between the counter and TTnCCR1 register.

| Next Count operation | Description                 |
|----------------------|-----------------------------|
| Up count             | Up count the counter value. |
| Down count           | Clear counter to 0000H.     |

#### 4. TTnECM1, 0 = 11B

 Operation is performed under the following conditions upon a match between the counter and TTnCCR0 register.

| Next count operation | Description                   |
|----------------------|-------------------------------|
| Up count             | Clear counter to 0000H.       |
| Down count           | Down count the counter value. |

 Operation is performed under the following conditions upon a match between the counter and TTnCCR1 register.

| Next count operation | Description                 |
|----------------------|-----------------------------|
| Up count             | Up count the counter value. |
| Down count           | Clear counter to 0000H.     |



**Caution** In encoder compare mode (TTnMD3 to TTnMD0 bits = 1000B), or encoder capture-compare mode (TTnMD3 to TTnMD0 bits = 1010B), if the compare registers (TTnCCR0, TTnCCR1) are set to the same value of TTnTCW register when TTnECC bit = 0, the timer cannot perform the comparison with the compare registers (TTnCCR0, TTnCCR1) and TTnTCW register (which is the start value of TTnCNT). In this case the "encoder clear mode on match of counter and compare register" does not work at the start timing (TTnECM0 = 1, and/or TTnECM1 = 1).



# (c) Counter load function for TTnCCR0 register setting value upon underflow (bit TTnLDE of register TTnCTL2))

The setting value of the TTnCCR0 register can be loaded to the counter upon counter underflow, by setting TTnLDE = 1.

Bit TTnLDE is valid in the encoder compare mode and encoder capture compare mode.

Count operation between 0000H and setting value of TTnCCR0 register setting:

Set TTnLDE = 1, TTnECM1, 0 = 01B and perform count operation. When TTnECM0 = 1, the counter is cleared to 0000H if the next count following a match between the counter and TTnCCR0 register is up count.

When TTnLDE = 1, the setting value of the TTnCCR0 register is loaded to the counter upon underflow.

Therefore, the setting value of the TTnCCR0 register is used as the maximum count value and count operation can be realized within "0000H-TTnCCR0 register setting values.



Figure 18-32 Encoder count function up/down count selection specification timings (6/6) - timing 6



# (5) Counter clearing to 0000H through encoder clear input (pin TECRTn) (TTnIOC3 register bits TTnSCE, TTnECS1, TTnECS0)

There are two methods to clear the counter to 0000H through TECRTn pin input, and encoder clear input is controlled by bit TTnSCE. Bits TTnZCL, TTnBCL, TTnACL, TTnECS1, and TTnECS0 are controlled by the setting of bit TTnSCE.

These clear methods are valid in the encoder compare mode, encoder capture mode, and encoder capture/compare mode.

| TTnSCE | TTnZCL       | TTnBCL       | TTnACL       | TTnECS1, 0   | Method |
|--------|--------------|--------------|--------------|--------------|--------|
| 0      | Invalid      | Invalid      | Invalid      | $\checkmark$ | <1>    |
| 1      | $\checkmark$ | $\checkmark$ | $\checkmark$ | Invalid      | <2>    |

1. Method to clear counter to 0000H through detection of valid edge of TECRTn pin input (TTnSCE = 0)

When TTnSCE = 0, the counter is cleared to 0000H in synchronization with the internal operation clock upon detection of the valid edge set through TECRTn pin input edge detection specification. At this time, an encoder clear interrupt (INTTTnEC) is output. When TTnSCE = 0, the setting of bits TTnZCL, TTnBCL, and TTnACL are invalid.



Figure 18-33 Counter clearing to 0000h through encoder clear input (pin tecrtn) timings (1/4) When TTnSCE = 0, TTnECS1, 0 = 01B, TTnUDS = 11B are Set



 Method to clear counter to 0000H through detection of level clear condition (TTnSCE = 1)

When TTnSCE = 1, the counter is cleared to 0000H according to the clear condition level of pins TECRTn, TENCTn1, and TENCTn0 set with bits TTnZCL, TTnBCL, and TTnACL. At this time, no encoder clear interrupt (INTTTnEC) is output. When TTnSCE = 1, the settings of bits TTnECS1 and TTnECS0 are invalid.

Operation example:

When TTnSCE = 1, TTnCLA = 1, TTnCLB = 0, TTnCLZ = 1, TTnUDS = 11B are set

<Clear condition level> TECRTn pin: High level, TENCTn1 pin: Low level, TENCTn0 pin: High level

| Signal after e | edge detection                     |
|----------------|------------------------------------|
| TENCTn0        |                                    |
| TENCTn1        | ) н                                |
| TECRTn         |                                    |
| Base clock     |                                    |
| Counter        |                                    |
|                | M X 0 X                            |
| Count clock    |                                    |
|                | When "m+1" set to TTnCCR0          |
| TTnCCR0        | m+1                                |
| INTTTnCC0      | Compare match interrupt not output |
|                | When "0000H" set to TTnCCR1        |
| TTnCCR1        | 0                                  |
| INTTTnCC1      |                                    |
|                | When "m" set to TTnCCR0            |
| TTnCCR0        | m                                  |
| INTTTnCC0      |                                    |

Figure 18-34 Counter clearing to 0000H through encoder clear input (pin TECRTn) timings (2/4) When TECRTn pin input is delayed from TENCTn1 pin input during up count





Figure 18-35 Counter clearing to 0000H through encoder clear input (pin TECRTn) timings (3/4)

When TECRTn pin input and TENCTn1 pin input occur simultaneously during up count



Figure 18-36 Counter clearing to 0000H through Encoder clear input (pin TECRTn) timings (3/4)

When TECRTn pin input occurs earlier than TENCTn1 pin input during up count

No miscount occurs due to TECRTn pin input delay because the clear condition is set according to the levels of pins TENCTn0, TENCTn1 and TECRTn, and the counter is cleared to 0000H upon clear condition detection.



| Signal at      | ter edge detection                 |
|----------------|------------------------------------|
| TENCTn0        | н                                  |
| TENCTn1        | L                                  |
| TECRTn         | Р                                  |
| Base clock     |                                    |
| Counter        | m X m-1 0 X                        |
| Count<br>clock |                                    |
|                | When "m-1" set to TTnCCR0          |
| TTnCCR0        | m-1                                |
| INTTTnCC0      | Compare match interrupt not output |
|                | When "0000H" set to TTnCCR1        |
| TTnCCR1        | 0                                  |
| INTTTnCC1      |                                    |
|                | When "m" set to TTnCR0             |
| TTnCCR0        | m                                  |
| INTTTnCC0      |                                    |
|                |                                    |

Figure 18-37 Counter clearing to 0000H through encoder clear input (pin TECRTn) timings (4/4)

When TECRTn pin input occurs later than TENCTn1 pin input during down count

No miscount occurs due to the TECRTn pin input delay during down count, similarly to during up count.



### (6) Counter hold through bit TTnECC

By setting TTnCTL2 register bit TTnECC to 1, it is possible to switch to an encoder mode other than the currently operating mode during timer operation in the encoder compare mode, encoder capture mode, and encoder capture/compare mode. The capture function/compare function of the TTnCCR0 and TTnCCR1 registers can be switched by switching the operation mode.

#### (a) Mode switching using bit TTnECC

To switch the encoder mode while holding the counter value, be sure to set TTnECC = 1 before setting TTnCE = 0.

Since the counter gets reset if TTnCE = 0 is set with TTnECC = 0 left unchanged, the counter value cannot be held in this case.



**Caution** To change the mode setting TTnCE = 0 once while the encoder itself is operating, perform initial setting processing within 1 cycle of the count clock. If switching is performed through bit TTnECC at the count signal output timing, miscount will occur.



#### (b) Initial counter operation through bit TTnECC setting



#### Figure 18-39 Counter hold through bit TTnECC timings (2/8) Count operation when TTnECC = 0 is set

The setting value of the TTnTCW register is loaded to the counter and count operation is performed from the setting value of the TTnTCW register.

(Initial value 0000H of TTnTCW register)

| Base clock                 |      |      |   |       |           |
|----------------------------|------|------|---|-------|-----------|
| TTnECC                     | High |      |   |       |           |
| TTnCE _                    |      |      |   |       |           |
| Internal<br>count signal _ |      |      |   |       |           |
| Counter                    | F    | FFFH |   | 0000H | $\supset$ |
| TTnTCW (                   | (    |      | m |       |           |
|                            |      |      |   |       |           |

Figure 18-40 Counter hold through bit TTnECC timings (2/8) Count operation when TTnECC = 1 is set

Since the setting value of the TTnTCW register is not loaded to the counter, the count operation is performed from initial value FFFFH.

As the initial operation, it is recommended to set TTnECC = 0 and load to the counter the value set to the TTnTCW register, then start the count operation.



#### (c) Bit TTnECC rewrite timing and its influence on counter

1. When setting value of bit TTnECC is rewritten  $0 \rightarrow 1 \rightarrow 0$  when TTnCE = 1: Even if bit TTnECC rewrite is performed while TTnCE = 1, this has no influence on the counter operation.

Judgment as whether to hold or reset the counter value is performed while TTnCE = 0.

Moreover, judgment as to whether to load the setting value of the TTnTCW register to the counter is performed at the timing when the value of bit TTnCE changes from 0 to 1.



- Figure 18-41 Counter hold through bit TTnECC timings (3/8) When setting value of bit TTnECC is rewritten  $0 \rightarrow 1 \rightarrow 0$  when TTnCE = 1
  - 2. When setting value of bit TTnECC is rewritten  $1 \rightarrow 0 \rightarrow 1$  while TTnCE = 0: The counter is reset when the setting value of bit TTnECC is changed from 1 to 0 while TTnCE = 0

Then, when TTnECC = 1 is set again and the value of bit TTnCE is changed from 0 to 1, counting restarts from the counter's initial value FFFFH, without the setting value of the TTnTCW being loaded to the counter.



Figure 18-42 Counter hold through bit TTnECC timings (3/8) When setting value of bit TTnECC is rewritten  $1 \rightarrow 0 \rightarrow 1$  while TTnCE = 0

RENESAS

## (d) Rewrite timing of bit TTnECC

When TTnCE = 0 and TTnECC = 0, setting TTnCE = 1 causes the setting value of the TTnTCW register to be loaded to the counter.

Perform rewrite of the TTnECC bit after the operation clock has become valid (after several clocks: TBD), following setting of TTnCE = 1.

If bit TTnECC is rewritten before the operation clock becomes valid, counting starts from FFFFH without loading the setting value of the TTnTCW register to the counter.

< Register setting conditions>

| TTnCTL0:<br>TTnMD3 to 0 = 1000B            | Encoder compare mode                                                          |
|--------------------------------------------|-------------------------------------------------------------------------------|
| TTnCTL1:<br>TTnUDS1, 0 = 00B               | Judgment of up/down count with count judgment mode 1                          |
| TTnCTL1:<br>TTnECM1, 0 = 01B               | Counter clear upon match between counter value and TTnCCR0 buffer register    |
| TTnCTL1:<br>TTnLDE = 1                     | Loading of setting value of TTnCCR0 register (p) upon<br>underflow occurrence |
| TTnIOC3:<br>TTnEIS1, 0 = 01B               | Detection of rising edge of TENCTn0 and TENCTn1 pin                           |
| TTnIOC3:<br>TTnSCE = 0,<br>TTnECS1-0 = 00B | Valid edge detection clear (no edge specified)                                |





RENESAS

Since TTnUDS1, 0 and TTnEIS1, 0 that control the count operation are set to 00B and 01B (rising edge detection), respectively, the counter is operated through detection of the phase of pin TENCTn1 upon detection of the rising edge of TENCTn0 pin input.

A compare match interrupt (INTTTnCC0) is output upon a match between the counter value and the TTnCCR0 compare register (p).

At this time, the counter is cleared to 0000H if the next count operation is up count.

A compare match interrupt (INTTTnCC1) is output upon a match between the counter value and the TTnCCR1 buffer register (q).

The counter is not cleared upon a match between the counter value and the TTnCCR1 register.

If underflow occurs when TTnLDE = 1 is set, the setting value of the TTnCCR0 buffer register (m) is loaded to the counter. A count operation is possible between 0000H and the setting value of the TTnCCR0 register by setting TTnLDE = 1 and TTnECM0 = 1.



<Setting conditions>

| TTnCTL0:<br>TTnMD3 to 0 = 1000B            | Encoder compare mode                                            |
|--------------------------------------------|-----------------------------------------------------------------|
| TTnCTL1:<br>TTnUDS1, 0 = 11B               | Judgment of up/down count with count judgment mode 4            |
| TTnCTL1:<br>TTnECM1, 0 = 00B               | No clear operation upon match between counter value and compare |
| TTnCTL1:<br>TTnLDE = 0                     | No loading of setting value of TTnCCR0 register (p) to counter  |
| TTnIOC3:<br>TTnSCE = 0,<br>TTnECS1-0 = 01B | Valid edge detection clear (rising edge specified)              |



#### Figure 18-44 Counter hold through bitTTnECC timings (5/8) Basic timing in encoder compare mode (2)

Since TTnUDS1, 0 that control the count operation are set to 11B, the counter is operated through detection of the phase of pins TENCTn0 and TENCTn1.

A compare match interrupt (INTTTnCC0) is output upon a match between the counter value and the TTnCCR0 buffer register (p).

A compare match interrupt (INTTTnCC1) is output upon a match between the counter value and the TTnCCR1 buffer register (q).

The counter is not cleared upon a match with the TTnCCR0 register or the TTnCCR1 register.

Clearing of the counter to 0000H is done upon detection of the valid edge of the encoder clear input (pin TECRTn) when TTnSCE = 0. When TTnECS = 01B is set, the counter is cleared to 0000H in

synchronization with the operation clock, following detection of the rising edge of the TECRTn pin input.



<Setting conditions>

| TTnCTL0:                                   | Encoder compare mode                                                                                                                                                                                                                            |
|--------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TTnMD3 to 0 = 1000B                        |                                                                                                                                                                                                                                                 |
| TTnCTL1:<br>TTnUDS1, 0 = 11B               | Judgment of up/down count with count judgment mode 4                                                                                                                                                                                            |
| TTnCTL1:<br>TTnECM1, 0 = 11B               | No clear operation upon match between counter value and compare                                                                                                                                                                                 |
| TTnCTL1:<br>TTnLDE = 0                     | Counter clear upon match between counter value and<br>TTnCCR0 buffer register<br>Counter clear upon match between counter value and<br>TTnCCR1 buffer register<br>(Since TTnCTL1: TTnECM1 to 0 = 11B, the setting of bit<br>TTnLDE is invalid.) |
| TTnIOC3:<br>TTnSCE = 0,<br>TTnECS1-0 = 00B | Valid edge detection clear (no edge specified)                                                                                                                                                                                                  |



Figure 18-45 Counter hold through bit TTnECC timings (6/8) Basic timing in encoder compare mode (3)

Since TTnUDS1, 0 that control the count operation are set to 11B, the counter is operated through detection of the phase of pins TENCTn0 and TENCTn1.

A compare match interrupt (INTTTnCC0) is output upon a match between the counter value and the TTnCCR0 buffer (p).

At this time, the counter is cleared to 0000H if the next count operation is up count.

A compare match interrupt (INTTTnCC1) is output upon a match between the counter value and the TTnCCR1 buffer (q).

At this time, the counter is cleared to 0000H if the next count operation is down count.

<Setting conditions>

RENESAS





| TTnCTL1:<br>TTnECM1, 0 = 01B                | Counter clear upon match between counter value and TTnCCR0 buffer register              |
|---------------------------------------------|-----------------------------------------------------------------------------------------|
| TTnCTL1:<br>TTnLDE = 1                      | Loading of setting value of TTnCCR0 register to<br>counter upon occurrence of underflow |
| TTnIOC3:<br>TTnEIS1, 0 = 01B                | Detection of rising edge of TENCTn0 and TENCTn1 pin inputs                              |
| TTnIOC3:<br>TTnSCE = 0,<br>TTnECS1, 0 = 00B | Valid edge detection clear (no edge specified)                                          |
| TTnOPT1:<br>TTnIS3, 2 = 01B                 | Detection of rising edge of TITn1 pin input                                             |



Figure 18-47 Counter hold through bit TTnECC timings (8/8) Basic timing in encoder capture compare mode (1)

Since TTnUDS1, 0 and TTnEIS1, 0 that controls the count operation are set to 00B and 01B (rising edge detection), respectively, the counter operates through detection of the rising edge of the TENCTn0 pin input and detection of the phase of the TENCTn1 pin.

A compare match interrupt (INTTTnCC0) is output upon a match between the counter value and the TTnCCR0 buffer register (m). At this time, the counter is cleared to 000H if the next count operation is up count.

Upon detection of the edge of the TITn1 pin input, the counter value is saved to the capture

register (TTnCCR1), and a capture interrupt (INTTTnCC1) is output.

If an underflow occurs due to the TTnLDE = 1 setting, the setting value of the TTnCCR0 buffer register is loaded to the counter. The count operation is possible between 0000H and the setting value of the TTnCCR0 register by setting TTnLDE = 1 and TTnECM0 = 1.

RENESAS

## 18.6.10 Offset trigger generation mode

In the offset trigger generation mode, the count value is saved to the capture register (TTnCCR0) upon detection of the valid edge of the TITn0 pin, and a capture interrupt (INTTTnCC0) is output. The counter is cleared to 0000H by capture input. (Counter clear operation is not performed using the TTnCCR1 register.)

The TTnCCR0 register and the TTnCCR1 register have their functions fixed as a capture register and a compare register, respectively. The TTnCCR1 register can be rewritten during count operation. Regarding compare register reload, the capture & clear timing upon detection of TITn0 pin input serves as the reload timing.

During count operation, a capture interrupt (INTTTnCC0) is output upon capture to the TTnCCR0 register through TITn0 pin input, and a compare match interrupt (INTTTnCC1) is output upon a match between the counter and the TTnCCR1 register.

The TOTn0 pin becomes the level set with bit TTnOL0. If TTnOL0 = 0, a low level is output a and if TTnOL0 = 1, a high level is output.

The TOTn1 pin is reset upon a match between the counter and the TTnCCR1 register, and is set when the counter is cleared to 0000H.



Figure 18-48 Basic timing in offset trigger generation mode



In the offset trigger generation mode, the setting value of the TTnCCR1 register is reloaded to the TTnCCR1 buffer register upon detection of the valid edge of pin TITn0. Until the edge of the TITn0 pin input is detected, the value of the TTnCCR1 register is not reloaded to the TTnCCR1 buffer register, even if this value is changed.

Pin TOTn1 is set when the counter is cleared to 0000H upon detection of the valid edge of pin TITn0, and it is reset upon a match between the counter value and the TTnCCR1 register.

Therefore, pin TOTn1 remains high level if the valid edge of the TITn0 pin input is detected before a match with the TTnCCR1 register occurs.

# 18.7 Cautions

# 18.7.1 TMT 'Encoder load enable'-mode limitation

#### Description If TMT operates

- in encoder compare mode (TTnCTL1.TTnMD[3:0] = 1000<sub>B</sub>)
- or in encoder capture/compare mode (TTnCTL1.TTnMD[3:0] = 1010<sub>B</sub>),
- and the 'Encoder load enable'-mode is set (TTnCTL2.TTnLDE = 1)

while the TMT operation is enabled (TTnCTL0.TTnCE = 1), an undefined value might be loaded into the counter (TTnCNT) when the TTnCCR0 register is rewritten during counter underflow.

- **Workaround** If the TMT 'Encoder load enable'-mode is set (TTnCTL2.TTnLDE = 1) during TMT operation in encoder compare mode (TTnCTL1.TTnMD[3:0] =  $1000_B$ ) or in encoder capture/compare mode (TTnCTL1.TTnMD[3:0] =  $1010_B$ ) apply either of the following workarounds:
  - Disable the TMT (TTnCTL0.TTnCE = 0) before rewriting the TTnCCR0 register.
  - Ensure that the TTnCCR0 register is not rewritten during a possible underflow of the counter (TTnCNT).



# **Chapter 19 Timer Interconnection**

Various functions can be implemented by connecting the timer I/O and the internal signal between timers.:

- 2-phase encoder function
- 3-phase pulse input control function
- 3-phase encoder function
- TMT as Filter for TMAA

The timer I/O control register (TAAIC3) is used for signal connection between timers. The following shows the timer I/O control registers according to their functions.





RENESAS

Figure 19-1 Time interconnection block diagram

Chapter 19



Figure 19-2 Timer AA configuration



# 19.1 Control register

# (1) TAAIC3 - Timer I/O control register 3

The TAAIC3 register selects the timer input signals for enhanced timer control.

Access This register can be read/written in 8-bit or 1-bit units.

Address FFFF F6F3<sub>H</sub>

Initial Value 00<sub>H</sub>

| 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|---------|---------|---------|---------|---------|---------|---------|---------|
| TAAIC37 | TAAIC36 | TAAIC35 | TAAIC34 | TAAIC33 | TAAIC32 | TAAIC31 | TAAIC30 |
| R/W     |

| Table 19-1 | <b>TAAIC3</b> register contents | (1/2) |  |
|------------|---------------------------------|-------|--|
|            |                                 |       |  |

| Bit position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                          |
| 7            | TAAIC37  | Selection of TMS1 TSTSTIC0/TSTSTIC1 input signal<br>0: "L" signal level TMS1 TSTSTIC1<br>TMS1 TSTSTIC0: input selected by TAAIC33 bit<br>1: TMS1 TSTSTIC0: TMT0 TTTEQC1<br>TMS1 TSTSTIC1: TMT1 TTTEQC1                                                                                                                                                                                            |
| 6            | TAAIC36  | Selection of TMS0 TSTSTIC0/TSTSTIC1 input signal<br>0: "L" signal level TMS0 TSTSTIC1<br>TMS0 TSTSTIC0: input selected by TAAIC31 bit<br>1: TMS0 TSTSTIC0: TMT0 TTTEQC1<br>TMS0 TSTSTIC1: TMT1 TTTEQC1                                                                                                                                                                                            |
| 5            | TAAIC35  | Signal selection input to selector controlled by TAAIC34 bit<br>0: TMS0 TSTAEDO<br>1: TMS1 TSTAEDO                                                                                                                                                                                                                                                                                                |
| 4            | TAAIC34  | Selection of TMTn (n = 0 - 1) TTTECR/TTTTI0 input signal0: "L" level of "L" level of<br>TMS1<br>0: TMT0 TTTECR:TECRT0<br>TMT1 TTTECR:TECRT1<br>TMT0 TTTTI0:TIT00<br>TMT1 TTTTI0:TIT10<br>1: TMT1 TTTTI0: selected by TAAIC35 bitt<br>TMT0 TTTTI0: selected by TAAIC35 bitt<br>TMT1 TTTECR: selected by TAAIC35 bitt<br>TMT0 TTTECR: selected by TAAIC35 bitt                                      |
| 3            | TAAIC33  | Selection of TMS1 TSTARD 120 degree energizing pattern switch sequence control<br>signal and Signal selection input to selector controlled by TAAIC37 bit.<br>0: "L" level of "L" level at TMS1 TSTARD input<br>TAAIC37 selector input (for TMS1 TSTSTCI1)<br>1: TMS1 TSTARD:TTTTO0 (from TMT0)<br>TAAIC37 selector (for TMS1 TSTSTCI0): TTTEQC0 or TTTEQC1 from TMT1,<br>selected it with TTTTO0 |
| 2            | TAAIC32  | Selection of TMT1 TTTENC0/TTTENC1 encoder input signal<br>0: TMT1 TTTENC0:TIT11/TEVTT0/TENCT10<br>TMT1 TTTENC1:TIT10/TTRGT0/TENCT11<br>1: TMT1 TTTENC0:TSTESG (from TMS1)<br>TMT1 TTTENC1:TSTTSF(from TMS1)                                                                                                                                                                                       |

RENESAS

| Bit position | Bit name | Function                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1            | TAAIC31  | Selection of TMS0 TSTARD 120 degree energizing pattern switch sequence control<br>signal and Signal selection input to selector controlled by TAAIC36 bit<br>0: "L" level of "L" level at TMS0 TSTARD input<br>TAAIC36 selector input (for TMS0 TSTSTCI1)<br>1: TMS0 TSTARD:TTTTO0 (from TMT0)<br>TAAIC36 selector (for TMS0 TSTSTCI0): TTTEQC0 or TTTEQC1 from TMT0<br>selected with TTTTO0 |
| 0            | TAAIC30  | Selection of TMT0 TTTENC0/TTTENC1 encoder input signal<br>0: TMT0 TTTENC0:TIT00/TEVTT1/TENCT00<br>TMT0 TTTENC1:TIT01/TTRGT1/TENCT01<br>1: TMT0 TTTENC0:TSTESG(from TMS0)<br>TMT0 TTTENC1:TSTTSF(from TMS0)                                                                                                                                                                                   |

 Table 19-1
 TAAIC3 register contents (2/2)



# **19.2 2-Phase Encoder Control Function**

# 19.2.1 Function overview

The function enables shifting of the timer S output pattern, such as  $120^\circ$  conducting control by use of the 2-phase encoder.

| Method           | Encoder counter count cycle          | Encoder counter clear method                          |  |  |
|------------------|--------------------------------------|-------------------------------------------------------|--|--|
| Control method 1 | 1 motor rotation                     | Clear by Z-phase input                                |  |  |
| Control method 2 | Arbitrary cycle                      | Arbitrary value                                       |  |  |
| Control method 3 | Count value to shift timer S pattern | Clear by compare value (count value to shift pattern) |  |  |

The internal signals used in the 2-phase control function are shown below.

| Timer    | Signal name | I/O | Function                                                                                                                                                                                        |
|----------|-------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | TSnARD      | I   | Controls the TOSn1 to TOSn6 pin output pattern order.<br>Low level:Shifts the output pattern in normal rotation order.<br>High level:Shifts the output pattern in reverse rotation order.       |
|          | TSnSTCI0    | Ι   | Output pattern shift trigger                                                                                                                                                                    |
| <b>-</b> | TSnSTCI1    | Ι   | Low level should be input in the 2-phase encoder control function.                                                                                                                              |
| Timer S  | TSnADTRG0   | 0   | Conversion start trigger signal for A/D converter 0. When the A/D converter is used in timer trigger mode, the A/D conversion start trigger is set regardless of the signal connection setting. |
|          | TSnADTRG1   | 0   | Conversion start trigger signal for A/D converter 0. When the A/D converter is used in timer trigger mode, the A/D conversion start trigger is set regardless of the signal connection setting. |
|          | TTmENC0     | I   | Encoder A-phase input signal                                                                                                                                                                    |
|          | TTmENC1     | Ι   | Encoder B-phase input signal                                                                                                                                                                    |
|          | TTmECR      | Ι   | Encoder Z-phase input signal                                                                                                                                                                    |
| Timer T  | TTmTl0      | Ι   | Cycle measurement capture input signal                                                                                                                                                          |
|          | TTmTI1      | Ι   | Position detection capture input signal                                                                                                                                                         |
|          | INTTTmCC0   | 0   | Timer Tm TTmCCR0 compare match interrupt request signal                                                                                                                                         |
|          | INTTTmCC1   | 0   | Timer Tm TTmCCR1 compare match interrupt request signal                                                                                                                                         |

**Note** n = 0, 1, m = 0 to 5



# 19.2.2 Configuration

2-phase input control/position detection

## (1) Control method 1

The following three types of timer configurations enable 2-phase input control/position detection control.

| Timer    | Function                                    | Block diagram                                                                                     | Mode                                                                                                                                                                                                |
|----------|---------------------------------------------|---------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timer T0 | Encoder<br>position<br>detection            | Timer T0<br>TTOENC0<br>TTRGT0<br>TTOENC1<br>TTOECR<br>INTTTOCC0<br>INTTTOCC1<br>TOT00<br>Timer S0 | •Encoder capture<br>compare mode                                                                                                                                                                    |
| Timer S0 | Motor<br>control<br>(position<br>detection) |                                                                                                   | Any of the following<br>modes<br>•High-accuracy<br>T-PWM mode<br>and semi-<br>automatic drive<br>180° conduction<br>control function<br>•120° conduction<br>mode<br>Special 120°<br>conduction mode |

## Table 19-4 Control Method 1 Timer Configuration (1)



| Timer    | Function                                    | Block diagram                                                                                                | Mode                                                                                                                                                                                                |
|----------|---------------------------------------------|--------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timer T4 | Encoder<br>position<br>detection            | Timer T1<br>TTIENC0<br>TTRGT1©<br>TT1ENC1<br>TECRT1©<br>TT1ECR<br>INTT1CC0<br>INTTT1CC1<br>TOT10<br>Timer S1 | •Encoder capture<br>compare mode                                                                                                                                                                    |
| Timer S0 | Motor<br>control<br>(position<br>detection) |                                                                                                              | Any of the following<br>modes<br>•High-accuracy<br>T-PWM mode<br>and semi-<br>automatic drive<br>180° conduction<br>control function<br>•120° conduction<br>mode<br>Special 120°<br>conduction mode |

 Table 19-5
 Control Method 1 Timer Configuration (2)



# **19.3 3-Phase Pulse Input Control Function**

# 19.3.1 Function overview

Phase variable control for timer S pattern output is enabled by combining the 3-phase pulse input (TAPTSn2 to TAPTSn0 pin input) of the timer S0/S1 and timer S connection mode of timer T (n = 0, 1).

- Phase fix control: Outputs the pattern fixed at a certain rotation angle.
- Phase variable control: Outputs the pattern where the phase of angle (time) discretionary to the rotation angle is varied.



Figure 19-3 Phase fix control and phase variable control



Figure 19-4 Block diagram of 3-phase pulse input control



# 19.3.2 Configuration

# (1) 3-phase pulse input control 1

## Table 19-6 3-phase pulse input control 1 timer configuration

|             |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Setting                           |                                                                                                                                                                                                                |
|-------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timer       | Function          | Block diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Synchronous<br>function           | Operation<br>mode                                                                                                                                                                                              |
| Timer<br>T0 | Offset            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Simultaneous<br>start<br>(master) | Timer S<br>connetion                                                                                                                                                                                           |
| Timer<br>T1 | control           | Timer T1<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR<br>TT1ECR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Simultaneous<br>start<br>(slave)  | mode                                                                                                                                                                                                           |
| Timer<br>S0 | Pattern<br>output | TAPTS00 @<br>TAPTS01 @<br>TAPTS02 @<br>TAPTS03 @<br>TAPTS04 @<br>TAPTS05 @ | Simultaneous<br>start<br>(slave)  | <ul> <li>Any of the following modes</li> <li>High-accuracy T-PWM mode and semi-automatic drive 180° conduction control function</li> <li>120° conduction mode</li> <li>Special 120° conduction mode</li> </ul> |

# (2) 3-phase pulse input control 2



|             |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Setting                           |                                                                                                                                                                                                                |
|-------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timer       | Function          | Block diagram                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Synchronous<br>function           | Operation<br>mode                                                                                                                                                                                              |
| Timer<br>T0 | Offset            | Timer T0 TTOTIO<br>INTTTOCC1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Simultaneous<br>start<br>(master) | Timer S<br>connetion                                                                                                                                                                                           |
| Timer<br>T1 | control           | INTTOCC1<br>TIDECR<br>TIMER T1<br>TITTOLC1<br>TITTICC1<br>TITTICC1<br>TITTICC1<br>TITTICC1<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2<br>TITTICC2 | Simultaneous<br>start<br>(slave)  | mode                                                                                                                                                                                                           |
| Timer<br>S1 | Pattern<br>output |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Simultaneous<br>start<br>(slave)  | <ul> <li>Any of the following modes</li> <li>High-accuracy T-PWM mode and semi-automatic drive 180° conduction control function</li> <li>120° conduction mode</li> <li>Special 120° conduction mode</li> </ul> |

 Table 19-7
 3-phase pulse input control 2 timer configuration



# **19.4 3-Phase Encoder Function**

# 19.4.1 Function overview

The edges of the signals input to the TAPTS02 to TAPTS00 pins can be connected to any one of timers T0 to T3 to be counted.

# 19.4.2 Configuration

| Table 19-8 | Block diagram of 3-phase encoder (1) |
|------------|--------------------------------------|
|------------|--------------------------------------|





| Timer                    | Function                          | Block diagram                                                                                  | Mode                                                                                                                                                                                                           |
|--------------------------|-----------------------------------|------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timer T0<br>Timer<br>AA9 | Encoder                           | Timer T1<br>TTTENC1<br>TTTENC0<br>Timer TAA9<br>TAATTI0<br>TAATTI1<br>TAATTI1                  | <ul> <li>Any of the following modes</li> <li>Encoder compare mode</li> <li>Encoder capture mode</li> <li>Encoder capture compare mode</li> </ul>                                                               |
| Timer S1                 | TAPTS02<br>to<br>TAPTS00<br>input | Timer S1<br>TSTESG<br>TSTTSF<br>TAPTS10<br>TAPTS11<br>TAPTS12<br>TSTAPT0<br>TSTAPT1<br>TSTAPT2 | <ul> <li>Any of the following modes</li> <li>High-accuracy T-PWM mode and semi-automatic drive 180° conduction control function</li> <li>120° conduction mode</li> <li>Special 120° conduction mode</li> </ul> |

# Table 19-9Block diagram of 3-phase encoder (2)



# 19.5 TMT as Filter for TMAA

To support an extended filtering function (i.e. jittering input signals) for the input of TMAA8, there is a connectivity possible between TMT0 and TMAA8. Via this connectivity the INTTnCC0/1 interrupt signals can be chosen as capture-inputs for the CCR0/1 register of TMAA8 (refer also to the description of TAAIC2.TAAIC22 in *"Input Selection Registers" on page 549*).



# Chapter 20 On-Chip Debug Unit

The microcontroller includes an on-chip debug unit. By connecting an N-Wire emulator, on-chip debugging can be executed.

# 20.1 Functional Outline

# 20.1.1 Debug functions

### (1) Debug interface

Communication with the host machine is established by using the DRST, DCK, DMS, DDI, and DDO signals via an N-Wire emulator. The communication specifications of N-Wire are used for the interface.

## (2) On-chip debug

On-chip debugging can be executed by preparing wiring and a connector for on-chip debugging on the target system. An N-Wire emulator is used to connect the host PC to the on-chip debug unit.

## (3) Forced reset function

The microcontroller can be forcibly reset.

### (4) Break reset function

The CPU can be started in the debug mode immediately after reset of the CPU is released.

## (5) Forced break function

Execution of the user program can be forcibly aborted.

### (6) Hardware break function

Two breakpoints for instruction and data access can be used. The instruction breakpoint can abort program execution at any address. The access breakpoint can abort program execution by data access to any address.

## (7) Software break function

Up to eight software breakpoints can be set in the internal flash memory area. The number of software breakpoints that can be set in the RAM area differs depending on the debugger to be used.



#### (8) Debug monitor function

A memory space for debugging that is different from the user memory space is used during debugging (background monitor mode). The user program can be executed starting from any address.

While execution of the user program is aborted, the user resources (such as memory and I/O) can be read and written, and the user program can be downloaded.

#### (9) Mask function

Each of the following signals can be masked. That means these signals will not be effective during debugging.

The correspondence with the mask functions of the debugger (ID850NWC) for the N-Wire emulator (IE-V850E1-CD-NW) of Renesas Electronics is shown below.

| <ul> <li>– NMI0 mask function:</li> </ul> | NMI pin            |
|-------------------------------------------|--------------------|
| - RESET mask function:                    | external RESET pin |
| - WAIT mask function:                     | external WAIT pin  |

## (10) Timer function

The execution time of the user program can be measured.



# 20.1.2 Security function

This microcontroller has a N-Wire security function, that demands the user to input an ID code upon start of the debugger. The ID code is compared to a predefined ID code, written in advance to the internal flash memory by an external flash programmer. This function prevents unauthorized persons to operate the microcontroller in N-Wire debug mode and to read the internal flash memory area.

The ID code in the internal flash memory can only be written by an external flash programmer. It can't be changed in self-programming mode and therefore also not in N-Wire debugging mode.

**ID code** Be sure to write an ID code when writing a program to the internal flash memory.

The area of the ID code is 10 bytes wide and in the range of addresses 0000 0070\_H to 0000 0079\_H.

| Address                | ID code         |
|------------------------|-----------------|
| 0000 0079 <sub>H</sub> | FF <sub>H</sub> |
| 0000 0078 <sub>H</sub> | FF <sub>H</sub> |
| 0000 0077 <sub>H</sub> | FF <sub>H</sub> |
| 0000 0076 <sub>H</sub> | FF <sub>H</sub> |
| 0000 0075 <sub>H</sub> | FF <sub>H</sub> |
| 0000 0074 <sub>H</sub> | FF <sub>H</sub> |
| 0000 0073 <sub>H</sub> | FF <sub>H</sub> |
| 0000 0072 <sub>H</sub> | FF <sub>H</sub> |
| 0000 0071 <sub>H</sub> | FF <sub>H</sub> |
| 0000 0070 <sub>H</sub> | FF <sub>H</sub> |

The ID code when the memory is erased is shown below.

Security bit Bit 7 of address 0000 0079<sub>H</sub> enables or disables use of the N-Wire emulator.

- Bit 7 of address 0000 0079<sub>H</sub>
  - 0: disabled N-Wire emulator cannot connect to the on-chip debug unit.
  - 1: enabled N-Wire emulator can connect to the on-chip debug unit if the 10-byte ID code input matches the ID code stored in the flash memory

This security bit can only be modified by programming the flash memory via an external flash programmer. It is not possible to modify the security bit in self-programming mode, and therefore also not in N-Wire debugging mode.

After reset, the entire ID code area is set to FF<sub>H</sub>. This means that

- N-Wire debugging is generally enabled
- the ID code is FF<sub>H</sub> for all ID code bytes

Consequently, controller access is possible without any restriction.

**Caution** If access via the N-Wire interface should be disabled "block erase disabled" should be configured as well. Otherwise the flash memory blocks containing the ID code could be erased and N-Wire access could be enabled.



# 20.2 Connection to N-Wire Emulator

To connect the N-Wire emulator, a connector for emulator connection and a connection circuit must be mounted on the target system.

As a connector example the KEL connector is described in more detail. Other connectors, like for instance MICTOR connector (product name: 2-767004-2, Tyco Electronics AMP K.K.), are available as well. For the mechanical and electrical specification of these connectors refer to user's manual of the emulator to be used.

# 20.2.1 KEL connector

KEL connector product names:

- 8830E-026-170S (KEL): straight type
- 8830E-026-170L (KEL): right-angle type



Figure 20-1 Connection to N-Wire emulator (Renesas Electronics IE-V850E1-CD-NW: N-Wire Card)



## (1) Pin configuration

*Figure 20-2* shows the pin configuration of the connector for emulator connection (target system side), and *Table 20-1 on page 1039* shows the pin functions.



Figure 20-2 Pin configuration of connector for emulator connection (target system side)

**Caution** Evaluate the dimensions of the connector when actually mounting the connector on the target board.



# (2) Pin functions

The following table shows the pin functions of the connector for emulator connection (target system side). "I/O" indicates the direction viewed from the device.

| Table 20-1 | Pin functions of connector for emulator connection (target system side) |
|------------|-------------------------------------------------------------------------|
|------------|-------------------------------------------------------------------------|

| Pin no. | Pin name     | I/O    | Pin function                                                   |
|---------|--------------|--------|----------------------------------------------------------------|
| A1      | (Reserved 1) | -      | (Connect to GND)                                               |
| A2      | (Reserved 2) | -      | (Connect to GND)                                               |
| A3      | (Reserved 3) | -      | (Connect to GND)                                               |
| A4      | (Reserved 4) | -      | (Connect to GND)                                               |
| A5      | (Reserved 5) | -      | (Connect to GND)                                               |
| A6      | (Reserved 6) | -      | (Connect to GND)                                               |
| A7      | DDI          | Input  | Data input for N-Wire interface                                |
| A8      | DCK          | Input  | Clock input for N-Wire interface                               |
| A9      | DMS          | Input  | Transfer mode select input for N-Wire interface                |
| A10     | DDO          | Output | Data output for N-Wire interface                               |
| A11     | DRST         | Input  | On-chip debug unit reset input                                 |
| A12     | RESET        | Input  | Reset input.                                                   |
| A13     | FLMD0        | Input  | Control signal for flash download (flash memory versions only) |
| B1      | GND          | -      | -                                                              |
| B2      | GND          | -      | -                                                              |
| B3      | GND          | -      | -                                                              |
| B4      | GND          | -      | -                                                              |
| B5      | GND          | -      | -                                                              |
| B6      | GND          | -      | -                                                              |
| B7      | GND          | -      | -                                                              |
| B8      | GND          | -      | -                                                              |
| B9      | GND          | -      | -                                                              |
| B10     | GND          | -      | -                                                              |
| B11     | (Reserved 8) | -      | (Connect to GND)                                               |
| B12     | (Reserved 9) | -      | (Connect to GND)                                               |
| B13     | Vdd          | -      | 3.3 V input (for monitoring power supply to target)            |

- Caution 1. The connection of the pins not supported by the microcontroller is dependent upon the emulator to be used.
  - 2. The pattern of the target board must satisfy the following conditions.
    - The pattern length must be 100 mm or less.
    - The clock signal must be shielded by GND. •

RENESAS

#### (3) Example of recommended circuit

An example of the recommended circuit of the connector for emulator connection (target system side) is shown below.



Figure 20-3 Example of recommended emulator connection circuit

- Note 1. The pattern length must be 100 mm or less.
  - 2. Shield the DCK signal by enclosing it with GND.
  - 3. This pin is used to detect power to the target board. Connect the voltage of the N-Wire interface to this pin.
- **Caution** The N-Wire emulator may not support a 5 V interface and may require a level shifter. Refer to the user's manual of the emulator to be used.



# 20.3 Restrictions and Cautions on On-Chip Debug Function

- Do not mount a device that was used for debugging on a mass-produced product (this is because the flash memory was rewritten during debugging and the number of rewrites of the flash memory cannot be guaranteed).
- The RESET signal input is masked during a break.
- The on-chip debugging unit uses the exception vector address 60<sub>H</sub> for software breakpoint (DBTRAP, refer to *"Interrupt Controller (INTC)" on page 99*). Thus the debugger takes over control when one of the following exceptions occur:
  - debug trap (DBTRAP)
  - illegal op-code detection (ILGOP)
  - ROM Correction (if supported by the microcontroller)

The debugger executes its own exception handler. Therefore, the user's exception handler at address  $60_H$  will not be executed.



# Chapter 21 Auxiliary Frequency Output Function (AFO)

This microcontroller has an Auxiliary Frequency Output Function (AFO).

# 21.1 Features

- Frequency up to 8 Mbps
- Programmable frequency output
- Interval timer function
- Interrupt request signal (INTBRG2)

# 21.2 Configuration

The AFO function includes the following hardware.

## Table 21-1 AFO Configuration

| Item              | Configuration                                  |  |
|-------------------|------------------------------------------------|--|
| Control registers | bl registers Prescaler mode register 2 (PRSM2) |  |
|                   | Prescaler compare register 2 (PRSCM2)          |  |



Figure 21-1 Block diagram of Auxiliary Frequency Output Function

Note PCLK0: 32 MHz peripheral clock (refer to "Clock Generator" on page 148)



# 21.3 Control Registers

## (1) PRSM2 - Prescaler mode register 2

The PRSM2 register controls generation of a baud rate signal for the AFO function.

Access This register can be read/written in 8-bit or 1-bit units.

Address FFFF FDE0<sub>H</sub>

**Initial Value**  $00_{\text{H}}$ . This register is initialized by **RESET**.

Reset input clears this register to 00<sub>H</sub>.

| 7   | 6   | 5   | 4     | 3   | 2      | 1      | 0      |
|-----|-----|-----|-------|-----|--------|--------|--------|
| 0   | 0   | 0   | BGCE2 | 0   | TODIS2 | BGCS21 | BGCS20 |
| R/W | R/W | R/W | R/W   | R/W | R/W    | R/W    | R/W    |

## Table 21-2 PRSM2 register contents

| Bit position | Bit name         | Function                            |        |                                                                  |            |                          |  |  |  |
|--------------|------------------|-------------------------------------|--------|------------------------------------------------------------------|------------|--------------------------|--|--|--|
| 4, 2         | BGCE2,<br>TODIS2 | Sets the baud rate generator output |        |                                                                  |            |                          |  |  |  |
|              |                  | BGCE                                | TODIS2 | AFO                                                              | INTBRG2    | Counter                  |  |  |  |
|              |                  | 0                                   | 0      | fixed on 0                                                       | fixed on 0 | fixed on 01 <sub>H</sub> |  |  |  |
|              |                  | 0                                   | 1      | fixed on 0                                                       | fixed on 0 | fixed on 01 <sub>H</sub> |  |  |  |
|              |                  | 1                                   | 0      | active                                                           | active     | active                   |  |  |  |
|              |                  | 1                                   | 1      | fixed on 0                                                       | active     | active                   |  |  |  |
|              |                  |                                     |        |                                                                  |            |                          |  |  |  |
|              | BGCS2[1:0]       | Sets the baud rate generator clock  |        |                                                                  |            |                          |  |  |  |
|              |                  | BGCS21                              | BGCS20 | S20 Baud Rate Generator Clock<br>Selection (f <sub>BGCS2</sub> ) |            | Setting Value<br>(k)     |  |  |  |
| 1 to 0       |                  | 0                                   | 0      | f <sub>PCLK0</sub> / 1                                           |            | 0                        |  |  |  |
|              |                  | 0                                   | 1      | f <sub>PCLK0</sub> / 2                                           |            | 1                        |  |  |  |
|              |                  | 1                                   | 0      | f <sub>PCLK0</sub> / 4                                           |            | 2                        |  |  |  |
|              |                  | 1                                   | 1      | f <sub>PCLK0</sub> / 8                                           |            | 3                        |  |  |  |

Caution 1. Do not rewrite the PRSM2 register during operation.

2. Set bits BGCS21, BGCS20 and TODIS2 before setting the BGCE2 bit to 1.



## (2) PRSCM2 - Prescaler compare registers 2

The PRSCM2 register is an 8-bit compare register. Together with the clock selected in the PRSM2 register, this register sets the clock of the AFO.

Access This register can be read/written in 8-bit or 1-bit units.

Address FFFF FDE1<sub>H</sub>

Initial Value 00<sub>H</sub>. This register is initialized by RESET.

| 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|---------|---------|---------|---------|---------|---------|---------|---------|
| PRSCM27 | PRSCM26 | PRSCM25 | PRSCM24 | PRSCM23 | PRSCM22 | PRSCM21 | PRSCM20 |
| R/W     |

### Table 21-3 PRSM2 register contents

| Bit position | Bit name        |                    | Function |         |   |         |         |         |                         |                       |   |
|--------------|-----------------|--------------------|----------|---------|---|---------|---------|---------|-------------------------|-----------------------|---|
|              | PRSCM2<br>[7:0] | Sets the AFO clock |          |         |   |         |         |         |                         |                       |   |
|              |                 | 2                  | PRSCM27  | PRSCM26 |   | PRSCM22 | PRSCM21 | PRSCM20 | AFO clock               | Ν                     |   |
|              |                 |                    | 0        | 0       |   | 0       | 0       | 0       | f <sub>BGCS2</sub> /256 | 256                   |   |
|              |                 |                    | 0        | 0       |   | 0       | 0       | 1       | f <sub>BGCS2</sub>      | 1                     |   |
|              |                 |                    | 0        | 0       |   | 0       | 1       | 0       | f <sub>BGCS2</sub> /2   | 2                     |   |
| 7 to 0       |                 |                    |          | 0       | 0 |         | 0       | 1       | 1                       | f <sub>BGCS2</sub> /3 | 3 |
| 7 10 0       |                 |                    |          |         |   |         |         |         |                         |                       |   |
|              |                 |                    | 1        | 1       |   | 1       | 0       | 0       | f <sub>BGCS2</sub> /252 | 252                   |   |
|              |                 |                    | 1        | 1       |   | 1       | 0       | 1       | f <sub>BGCS2</sub> /253 | 253                   |   |
|              |                 |                    | 1        | 1       |   | 1       | 1       | 0       | f <sub>BGCS2</sub> /254 | 254                   |   |
|              |                 |                    | 1        | 1       |   | 1       | 1       | 1       | f <sub>BGCS2</sub> /255 | 255                   |   |
|              |                 |                    |          |         |   |         |         |         |                         |                       |   |

Caution 1. Do not rewrite the PRSCM2 register during operation.

2. Set the PRSCM2 register before setting the PRSM2.BGCE2 bit to 1.

3. Do not set the AFO clock to a frequency higher than 8 MHz.

Note f<sub>BGCS2</sub>: Clock frequency selected by bits PRSM2.BGCS2[1:0].



## 21.4 Operation

#### 21.4.1 Auxiliary frequency generation

The auxiliary frequency output clock is generated by dividing the main clock. The baud rate generated from the main clock is obtained by the following equation.

$$f_{AFO} = \frac{f_{BGCS2}}{N \times 2} = \frac{f_{XX}}{2^{(k+2)} \times N \times 2}$$

| f <sub>AFO</sub>   | AFO clock                                                                                                                                           |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| f <sub>BGCS2</sub> | Clock frequency selected by bits PRSM2.BGCS21and PRSM2.BGCS20                                                                                       |
| f <sub>XX</sub>    | Main clock oscillation frequency                                                                                                                    |
| k                  | PRSM2 register setting value ( $0 \le k \le 3$ )                                                                                                    |
| N                  | <ul> <li>if PRSCM2 = 01<sub>H</sub> to FF<sub>H</sub>: N = PRSCM2 register value (1 to 255)</li> <li>if PRSCM2 = 00<sub>H</sub>: N = 256</li> </ul> |

#### 21.4.2 Interval timer function

The AFO function can be used as interval timer regardless whether the auxiliary frequency output is used or not. For this purpose an interrupt request signal (INTBRG2) is assigned, which can be handled like any maskable interrupt.



# **Chapter 22 Reset Function**

## 22.1 Features

- Reset function by RESET input
   Analog filter eliminates noise from the RESET pin
- Forced reset function by DCU (refer to "On-Chip Debug Unit" on page 1034)
- Clock Monitor reset CLMRES
- Reset function by DDI = L while DRST = L (N-Wire interface)

## 22.2 Configuration

During a system reset, most pins enter the high-impedance state.

Therefore, if an external device always requires a defined input level (e.g. external memory) a pull-up (or pull-down) resistor must be connected to each concerned output pin to prevent signal lines from floating. If no resistor is connected, the external device may be destroyed when these pins enter the high-impedance state.

For a list of all pin states after reset, see "Pin Functions during and after Reset" on page 67.

#### (1) Hardware status

With reset the hardware is initialized. When the reset status is released, program execution is started.

The following table describes the status of the clocks during reset and after reset release. Note that the clock status "operates" does not inevitably mean that any function using this clock source operates as well. The function may additionally require to be enabled by other means.

#### Table 22-1 Hardware status during and after reset

| Item                                                                                                  | During reset        | After reset                                                           |  |  |  |
|-------------------------------------------------------------------------------------------------------|---------------------|-----------------------------------------------------------------------|--|--|--|
| Main oscillator                                                                                       | Operation continues | Operation continues                                                   |  |  |  |
| Internal oscillator                                                                                   | Operation stopped   | Starts oscillation                                                    |  |  |  |
| PLL clocks                                                                                            | Operation stopped   | Starts operation                                                      |  |  |  |
| CPU system clock                                                                                      | Operation stopped   | Starts operation after PLL stabilization time                         |  |  |  |
| CPU                                                                                                   | Operation stopped   | Initialized and program execution starts after PLL stabilization time |  |  |  |
| Peripheral clocks                                                                                     | Operation stopped   | Start after PLL stabilization time                                    |  |  |  |
| On-chip peripheral functions                                                                          | Operation stopped   | Initialized and can be operated after PLL stabilization time          |  |  |  |
| I/O pins<br>(port/alternative function pins)See chapter "Pin Functions" on page 23 for a description. |                     |                                                                       |  |  |  |



#### (2) Register status

With each reset the registers of the CPU, internal RAM, and on-chip peripherals are initialized. After a reset, make sure to set the registers to the values needed within your program.

| Table 22-2 | Initial values of CPU and internal RAM after reset |
|------------|----------------------------------------------------|
|------------|----------------------------------------------------|

| On-chip hardware | )                 | Register name                                                                   | Initial value<br>after Reset                                                                                      |
|------------------|-------------------|---------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|
| CPU              | Program registers | General-purpose register (r0)                                                   | 0000 0000 <sub>H</sub>                                                                                            |
|                  |                   | General-purpose registers (r1 to r31)                                           | Undefined                                                                                                         |
|                  | System registers  | Program counter (PC)                                                            | 0000 0000 <sub>H</sub>                                                                                            |
|                  |                   | Program status word (PSW)                                                       | 0000 0020 <sub>H</sub>                                                                                            |
|                  |                   | Status saving registers during maskable interrupt (EIPC, EIPSW)                 | Undefined                                                                                                         |
|                  |                   | Status saving registers during non-maskable<br>interrupt (NMI)<br>(FEPC, FEPSW) | Undefined                                                                                                         |
|                  |                   | Status saving registers during CALLT execution (CTPC, CTPSW)                    | Undefined                                                                                                         |
|                  |                   | Status saving registers during exception/debug trap (DBPC, DBPSW)               | Undefined                                                                                                         |
|                  |                   | Interrupt source register (ECR)                                                 | 0000 0000 <sub>H</sub>                                                                                            |
|                  |                   | CALLT base pointer (CTBP)                                                       | Undefined                                                                                                         |
|                  |                   | Floating-point arithmetic control register (ECT)                                | 0000 0000 <sub>H</sub>                                                                                            |
|                  |                   | Floating-point arithmetic status register (EFG)                                 | 0000 0000 <sub>H</sub>                                                                                            |
| Internal RAM     |                   |                                                                                 | Undefined                                                                                                         |
| Peripherals      |                   | Macro internal registers                                                        | The reset values<br>of the various<br>registers are<br>given in the<br>chapters of the<br>peripheral<br>functions |



## 22.3 Operation

When a low-level signal is input to the **RESET** pin, a system reset is effected and each on-chip hardware is initialized.

When the oscillation stabilization time has elapsed, the external  $\overline{\text{RESET}}$  can be released. The internal PLL stabilization time counter (PSTC) is started after some delay, induced by the analog noise rejection filter. The PSTC counts 2<sup>14</sup> oscillator clocks (f<sub>X</sub>) and determines the PLL lock state. The internal system reset is released, the CPU is supplied with the PLL output clock and the user's software is started up.



Figure 22-1 Reset timing

- Note 1. If no clock is supplied (i.e. the oscillator does not work) the internal system reset will not be released independently from input level of the external RESET pin.
  - 2. During RESET the PLL is stopped. Therefore the PLL lock-up time is always necessary after RESET release.
  - 3. The on-chip debug function can force the activation of the system reset independently from input level of the RESET pin.



# **Appendix A Special Function Registers**

The following tables list all registers that are accessed via the NPB (Peripheral bus). The registers are called "special function registers" (SFR).

Table A-3 lists all CAN special function registers.

## A.1 CAN Registers

The CAN registers are accessible via the programmable peripheral area. The addresses are given as offsets to the programmable peripheral base address (refer to *"CAN module register and message buffer addresses" on page 393.*)

 Table A-3
 CAN special function registers (1/3)

| Address<br>offset | Register name                                                     | Shortcut  | 1   | 8   | 16  | 32 | Initial<br>value |
|-------------------|-------------------------------------------------------------------|-----------|-----|-----|-----|----|------------------|
| 0x000             | CAN0 Global Macro Control register                                | COGMCTRL  | -   | •   | R/W | -  | 0x0000           |
| 0x000             | CAN0 Global Macro Control register low byte                       | COGMCTRLL | R/W | R/W | -   | -  | 0x00             |
| 0x001             | CAN0 Global Macro Control register high byte                      | COGMCTRLH | R/W | R/W | -   | -  | 0x00             |
| 0x002             | CAN0 Global Macro Clock Selection register                        | COGMCS    | R/W | R/W | -   | -  | 0x0F             |
| 0x006             | CAN0 Global Macro Automatic Block Transmission register           | COGMABT   | -   | -   | R/W | -  | 0x0000           |
| 0x006             | CAN0 Global Macro Automatic Block Transmission register low byte  | COGMABTL  | R/W | R/W | -   | -  | 0x00             |
| 0x007             | CAN0 Global Macro Automatic Block Transmission register high byte | COGMABTH  | R/W | R/W | -   | -  | 0x00             |
| 0x008             | CAN0 Global Macro Automatic Block Transmission<br>Delay register  | COGMABTD  | R/W | R/W | -   | -  | 0x00             |
| 0x040             | CAN0 Module Mask 1 register lower half word                       | C0MASK1L  | -   | -   | R/W | -  | undefined        |
| 0x042             | CAN0 Module Mask 1 register upper half word                       | C0MASK1H  | -   | -   | R/W | -  | undefined        |
| 0x044             | CAN0 Module Mask 2 register lower half word                       | C0MASK2L  | -   | -   | R/W | -  | undefined        |
| 0x046             | CAN0 Module Mask 2 register upper half word                       | C0MASK2H  | -   | -   | R/W | -  | undefined        |
| 0x048             | CAN0 Module Mask 3 register lower half word                       | C0MASK3L  | -   | -   | R/W | -  | undefined        |
| 0x04A             | CAN0 Module Mask 3 register upper half word                       | C0MASK3H  | -   | -   | R/W | -  | undefined        |
| 0x04C             | CAN0 Module Mask 4 register lower half word                       | C0MASK4L  | -   | -   | R/W | -  | undefined        |
| 0x04E             | CAN0 Module Mask 4 register upper half word                       | C0MASK4H  | -   | -   | R/W | -  | undefined        |
| 0x050             | CAN0 Module Control register                                      | COCTRL    | -   | -   | R/W | -  | 0x0000           |
| 0x052             | CAN0 Module Last Error Code register                              | COLEC     | R/W | R/W | -   | -  | 0x00             |
| 0x053             | CAN0 Module Information register                                  | COINFO    | R   | R   | -   | -  | 0x00             |
| 0x054             | CAN0 Module Error Counter                                         | C0ERC     | -   | -   | R/W | -  | 0x0000           |
| 0x056             | CAN0 Module Interrupt Enable register                             | COIE      | -   | -   | R/W | -  | 0x0000           |
| 0x056             | CAN0 Module Interrupt Enable register low byte                    | COIEL     | R/W | R/W | -   | -  | 0x00             |
| 0x057             | CAN0 Module Interrupt Enable register high byte                   | COIEH     | R/W | R/W | -   | -  | 0x00             |



| Address<br>offset | Register name                                                     | Shortcut    | 1   | 8   | 16  | 32 | Initial<br>value      |
|-------------------|-------------------------------------------------------------------|-------------|-----|-----|-----|----|-----------------------|
| 0x058             | CAN0 Module Interrupt Status register                             | COINTS      | -   | -   | R/W | -  | 0x0000                |
| 0x058             | CAN0 Module Interrupt Status register low byte                    | COINTSL     | R/W | R/W | -   | -  | 0x00                  |
| 0x05A             | CAN0 Module Bit-Rate Prescaler register                           | COBRP       | R/W | R/W | -   | -  | 0xFF                  |
| 0x05C             | CAN0 Bit Rate register                                            | COBTR       | -   | -   | R/W | -  | 0x370F                |
| 0x05E             | CAN0 Module Last In-Pointer register                              | COLIPT      | -   | R/W | -   | -  | undefined             |
| 0x060             | CAN0 Module Receive History List Get Pointer register             | CORGPT      | -   | -   | R/W | -  | 0x??02<br>(undefined) |
| 0x060             | CAN0 Module Receive History List Get Pointer<br>register low byte | CORGPTL     | R/W | R/W | -   | -  | 0x02                  |
| 0x062             | CAN0 Module Last Out-Pointer register                             | COLOPT      | -   | R   | -   | -  | undefined             |
| 0x064             | CAN0 Module Transmit History List Get Pointer register            | COTGPT      | -   | -   | R/W | -  | 0x??02<br>(undefined) |
| 0x064             | CAN0 Module Transmit History List Get Pointer register low byte   | COTGPTL     | R/W | R/W | -   | -  | 0x02                  |
| 0x066             | CAN0 Module Time Stamp register                                   | COTS        | -   | -   | R/W | -  | 0x0000                |
| 0x066             | CAN0 Module Time Stamp register low byte                          | COTSL       | R/W | R/W | -   | -  | 0x00                  |
| 0x067             | CAN0 Module Time Stamp register high byte                         | COTSH       | R/W | R/W | -   | -  | 0x00                  |
| 0x100 to<br>0x4EF | CAN0 Message Buffer registers, see Table 14-20 or                 | n page 396. |     |     |     |    |                       |
| 0x600             | CAN1 Global Macro Control register                                | C1GMCTRL    | -   | -   | R/W | •  | 0x0000                |
| 0x600             | CAN1 Global Macro Control register low byte                       | C1GMCTRLL   | R/W | R/W | -   | -  | 0x00                  |
| 0x601             | CAN1 Global Macro Control register high byte                      | C1GMCTRLH   | R/W | R/W | -   | •  | 0x00                  |
| 0x602             | CAN1 Global Macro Clock Selection register                        | C1GMCS      | R/W | R/W | -   | •  | 0x0F                  |
| 0x606             | CAN1 Global Macro Automatic Block Transmission register           | C1GMABT     | -   | -   | R/W | -  | 0x0000                |
| 0x606             | CAN1 Global Macro Automatic Block Transmission register low byte  | C1GMABTL    | R/W | R/W | -   | -  | 0x00                  |
| 0x607             | CAN1 Global Macro Automatic Block Transmission register high byte | C1GMABTH    | R/W | R/W | -   | -  | 0x00                  |
| 0x608             | CAN1 Global Macro Automatic Block Transmission<br>Delay register  | C1GMABTD    | R/W | R/W | -   | -  | 0x00                  |
| 0x640             | CAN1 Module Mask 1 register lower half word                       | C1MASK1L    | -   | -   | R/W | -  | undefined             |
| 0x642             | CAN1 Module Mask 1 register upper half word                       | C1MASK1H    | -   | -   | R/W | -  | undefined             |
| 0x644             | CAN1 Module Mask 2 register lower half word                       | C1MASK2L    | -   | -   | R/W | -  | undefined             |
| 0x646             | CAN1 Module Mask 2 register upper half word                       | C1MASK2H    | -   | •   | R/W | •  | undefined             |
| 0x648             | CAN1 Module Mask 3 register lower half word                       | C1MASK3L    | -   | -   | R/W | -  | undefined             |
| 0x64A             | CAN1 Module Mask 3 register upper half word                       | C1MASK3H    | -   | -   | R/W | -  | undefined             |
| 0x64C             | CAN1 Module Mask 4 register lower half word                       | C1MASK4L    | -   | -   | R/W | -  | undefined             |
| 0x64E             | CAN1 Module Mask 4 register upper half word                       | C1MASK4H    | -   | -   | R/W | -  | undefined             |
| 0x650             | CAN1 Module Control register                                      | C1CTRL      | -   | -   | R/W | -  | 0x0000                |
| 0x652             | CAN1 Module Last Error Code register                              | C1LEC       | R/W | R/W | -   | -  | 0x00                  |
| 0x653             | CAN1 Module Information register                                  | C1INFO      | R   | R   | -   | -  | 0x00                  |
| 0x654             | CAN1 Module Error Counter                                         | C1ERC       | -   | -   | R/W | -  | 0x0000                |
| 0x656             | CAN1 Module Interrupt Enable register                             | C1IE        | -   | -   | R/W | •  | 0x0000                |

 Table A-3
 CAN special function registers (2/3)



| Address<br>offset | Register name                                                   | Shortcut    | 1   | 8   | 16  | 32 | Initial<br>value      |
|-------------------|-----------------------------------------------------------------|-------------|-----|-----|-----|----|-----------------------|
| 0x656             | CAN1 Module Interrupt Enable register low byte                  | C1IEL       | R/W | R/W | -   | -  | 0x00                  |
| 0x657             | CAN1 Module Interrupt Enable register high byte                 | C1IEH       | R/W | R/W | -   | -  | 0x00                  |
| 0x658             | CAN1 Module Interrupt Status register                           | C1INTS      | -   | -   | R/W | -  | 0x0000                |
| 0x658             | CAN1 Module Interrupt Status register low byte                  | C1INTSL     | R/W | R/W | -   | -  | 0x00                  |
| 0x65A             | CAN1 Module Bit-Rate Prescaler register                         | C1BRP       | R/W | R/W | -   | -  | 0xFF                  |
| 0x65C             | CAN1 Bit Rate register                                          | C1BTR       | -   | -   | R/W | -  | 0x370F                |
| 0x65E             | CAN1 Module Last In-Pointer register                            | C1LIPT      | -   | R/W | -   | -  | undefined             |
| 0x660             | CAN1 Module Receive History List Get Pointer register           | C1RGPT      | -   | -   | R/W | -  | 0x??02<br>(undefined) |
| 0x660             | CAN1 Module Receive History List Get Pointer register low byte  | C1RGPTL     | R/W | R/W | -   | -  | 0x02                  |
| 0x662             | CAN1 Module Last Out-Pointer register                           | C1LOPT      | -   | R   | -   | -  | undefined             |
| 0x664             | CAN1 Module Transmit History List Get Pointer register          | C1TGPT      | -   | -   | R/W | -  | 0x??02<br>(undefined) |
| 0x664             | CAN1 Module Transmit History List Get Pointer register low byte | C1TGPTL     | R/W | R/W |     | -  | 0x02                  |
| 0x666             | CAN1 Module Time Stamp register                                 | C1TS        | -   | -   | R/W | -  | 0x0000                |
| 0x666             | CAN1 Module Time Stamp register low byte                        | C1TSL       | R/W | R/W | -   | -  | 0x00                  |
| 0x667             | CAN1 Module Time Stamp register high byte                       | C1TSH       | R/W | R/W | -   | -  | 0x00                  |
| 0x700 to<br>0xAEF | CAN1 Message Buffer registers, see Table 14-20 c                | n page 396. | •   |     |     |    |                       |

#### Table A-3 CAN special function registers (3/3)



## A.2 Other Special Function Registers

| Table A-4 | Other special function registers (1/15) |
|-----------|-----------------------------------------|
|           |                                         |

| Address    | Register name                                      | Shortcut | 1   | 8   | 16  | 32 | Inital<br>value |
|------------|----------------------------------------------------|----------|-----|-----|-----|----|-----------------|
| 0xFFFFF064 | Peripheral area selection control register         | BPC      | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF06E | Internal peripheral function wait control register | VSWC     | R/W | R/W | -   | -  | 0x77            |
| 0xFFFFF100 | Interrupt mask control register 0                  | IMR0     | -   | -   | R/W | -  | 0xFFFF          |
| 0xFFFFF100 | Interrupt mask control register 0L                 | IMR0L    | R/W | R/W | -   | -  | 0xFF            |
| 0xFFFFF101 | Interrupt mask control register 0H                 | IMR0H    | R/W | R/W | -   | -  | 0xFF            |
| 0xFFFFF102 | Interrupt mask control register 1                  | IMR1     | -   | -   | R/W | -  | 0xFFFF          |
| 0xFFFFF102 | Interrupt mask control register 1L                 | IMR1L    | R/W | R/W | -   | -  | 0xFF            |
| 0xFFFFF103 | Interrupt mask control register 1H                 | IMR1H    | R/W | R/W | -   | -  | 0xFF            |
| 0xFFFFF104 | Interrupt mask control register 2                  | IMR2     | -   | -   | R/W | -  | 0xFFFF          |
| 0xFFFFF104 | Interrupt mask control register 2L                 | IMR2L    | R/W | R/W | -   | -  | 0xFF            |
| 0xFFFFF105 | Interrupt mask control register 2H                 | IMR2H    | R/W | R/W | -   | -  | 0xFF            |
| 0xFFFFF106 | Interrupt mask control register 3                  | IMR3     | -   | -   | R/W | -  | 0xFFFF          |
| 0xFFFFF106 | Interrupt mask control register 3L                 | IMR3L    | R/W | R/W | -   | -  | 0xFF            |
| 0xFFFFF107 | Interrupt mask control register 3H                 | IMR3H    | R/W | R/W | -   | -  | 0xFF            |
| 0xFFFFF108 | Interrupt mask control register 4                  | IMR4     | -   | -   | R/W | -  | 0xFFFF          |
| 0xFFFFF108 | Interrupt mask control register 4L                 | IMR4L    | R/W | R/W | -   | -  | 0xFF            |
| 0xFFFFF109 | Interrupt mask control register 4H                 | IMR4H    | R/W | R/W | -   | -  | 0xFF            |
| 0xFFFFF10A | Interrupt mask control register 5                  | IMR5     | -   | -   | R/W | -  | 0xFFFF          |
| 0xFFFFF10A | Interrupt mask control register 5L                 | IMR5L    | R/W | R/W | -   | -  | 0xFF            |
| 0xFFFFF10B | Interrupt mask control register 5H                 | IMR5H    | R/W | R/W | -   | -  | 0xFF            |
| 0xFFFFF10C | Interrupt mask control register 6                  | IMR6     | -   | -   | R/W | -  | 0xFFFF          |
| 0xFFFFF10C | Interrupt mask control register 6L                 | IMR6L    | R/W | R/W | -   | -  | 0xFF            |
| 0xFFFFF10D | Interrupt mask control register 6H                 | IMR6H    | R/W | R/W | -   | -  | 0xFF            |
| 0xFFFFF10E | Interrupt mask control register 7                  | IMR7     | -   | -   | R/W | -  | 0x001F          |
| 0xFFFFF10E | Interrupt mask control register 7L                 | IMR7L    | R/W | R/W | -   | -  | 0x1F            |
| 0xFFFFF10F | Interrupt mask control register 7H                 | IMR7H    | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF110 | Interrupt control register                         | ERRIC    | R/W | R/W | -   | -  | 0x47            |
| 0xFFFFF112 | Interrupt control register                         | OSDIC    | R/W | R/W | -   | -  | 0x47            |
| 0xFFFFF114 | Interrupt control register                         | PIC0     | R/W | R/W | -   | -  | 0x47            |
| 0xFFFFF116 | Interrupt control register                         | PIC1     | R/W | R/W | -   | -  | 0x47            |
| 0xFFFFF118 | Interrupt control register                         | PIC2     | R/W | R/W | -   | -  | 0x47            |
| 0xFFFFF11A | Interrupt control register                         | PIC3     | R/W | R/W | -   | -  | 0x47            |
| 0xFFFFF11C | Interrupt control register                         | PIC4     | R/W | R/W | -   | -  | 0x47            |
| 0xFFFFF11E | Interrupt control register                         | PIC5     | R/W | R/W | -   | -  | 0x47            |
| 0xFFFFF120 | Interrupt control register                         | PIC6     | R/W | R/W | -   | -  | 0x47            |
| 0xFFFFF122 | Interrupt control register                         | PIC7     | R/W | R/W | -   | -  | 0x47            |
| 0xFFFFF124 | Interrupt control register                         | PIC8     | R/W | R/W | -   | -  | 0x47            |
| 0xFFFFF126 | Interrupt control register                         | PIC9     | R/W | R/W | -   | -  | 0x47            |



#### Table A-4 Other special function registers (2/15)

| Address    | Register name              | Shortcut       | 1   | 8   | 16 | 32 | Inital<br>value |
|------------|----------------------------|----------------|-----|-----|----|----|-----------------|
| 0xFFFFF128 | Interrupt control register | PIC10          | R/W | R/W | -  |    | 0x47            |
| 0xFFFFF12A | Interrupt control register | PIC11          | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF12C | Interrupt control register | PIC12          | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF12E | Interrupt control register | TS0OVIC        | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF130 | Interrupt control register | TS0CCIC0       | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF132 | Interrupt control register | TS0CCIC1       | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF134 | Interrupt control register | TS0CCIC2       | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF136 | Interrupt control register | TS0CCIC3       | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF138 | Interrupt control register | TS0CCIC4       | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF13A | Interrupt control register | TS0CCIC5       | R/W | R/W | -  |    | 0x47            |
| 0xFFFFF13C | Interrupt control register | TS0CDIC0       | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF13E | Interrupt control register | TS0ODIC        | R/W | R/W | -  |    | 0x47            |
| 0xFFFFF140 | Interrupt control register | TS0ERIC        | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF142 | Interrupt control register | <b>TSOWNIC</b> | R/W | R/W | -  |    | 0x47            |
| 0xFFFFF144 | Interrupt control register | TS10VIC        | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF146 | Interrupt control register | TS1CCIC0       | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF148 | Interrupt control register | TS1CCIC1       | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF14A | Interrupt control register | TS1CCIC2       | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF14C | Interrupt control register | TS1CCIC3       | R/W | R/W | -  |    | 0x47            |
| 0xFFFFF14E | Interrupt control register | TS1CCIC4       | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF150 | Interrupt control register | TS1CCIC5       | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF152 | Interrupt control register | TS1CDIC0       | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF154 | Interrupt control register | TS10DIC        | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF156 | Interrupt control register | TS1ERIC        | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF158 | Interrupt control register | TS1WNIC        | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF15A | Interrupt control register | TT0OVIC        | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF15C | Interrupt control register | TT0CCIC0       | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF15E | Interrupt control register | TT0CCIC1       | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF160 | Interrupt control register | TT0ECIC        | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF162 | Interrupt control register | TT10VIC        | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF164 | Interrupt control register | TT1CCIC0       | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF166 | Interrupt control register | TT1CCIC1       | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF168 | Interrupt control register | TT1ECIC        | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF16A | Interrupt control register | TAA0OVIC       | R/W | R/W |    |    | 0x47            |
| 0xFFFFF16C | Interrupt control register | TAA0CCIC0      | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF16E | Interrupt control register | TAA0CCIC1      | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF170 | Interrupt control register | TAA1OVIC       | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF172 | Interrupt control register | TAA1CCIC0      | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF174 | Interrupt control register | TAA1CCIC1      | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF176 | Interrupt control register | TAA2OVIC       | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF178 | Interrupt control register | TAA2CCIC0      | R/W | R/W | -  |    | 0x47            |



#### Table A-4 Other special function registers (3/15)

| Address    | Register name              | Shortcut  | 1   | 8   | 16 | 32 | Inital<br>value |
|------------|----------------------------|-----------|-----|-----|----|----|-----------------|
| 0xFFFFF17A | Interrupt control register | TAA2CCIC1 | R/W | R/W | -  | •  | 0x47            |
| 0xFFFFF17C | Interrupt control register | TAA3OVIC  | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF17E | Interrupt control register | TAA3CCIC0 | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF180 | Interrupt control register | TAA3CCIC1 | R/W | R/W | -  |    | 0x47            |
| 0xFFFFF182 | Interrupt control register | TAA4OVIC  | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF184 | Interrupt control register | TAA4CCIC0 | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF186 | Interrupt control register | TAA4CCIC1 | R/W | R/W | -  |    | 0x47            |
| 0xFFFFF188 | Interrupt control register | TAA5OVIC  | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF18A | Interrupt control register | TAA5CCIC0 | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF18C | Interrupt control register | TAA5CCIC1 | R/W | R/W | -  |    | 0x47            |
| 0xFFFFF18E | Interrupt control register | TAA6OVIC  | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF190 | Interrupt control register | TAA6CCIC0 | R/W | R/W | -  |    | 0x47            |
| 0xFFFFF192 | Interrupt control register | TAA6CCIC1 | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF194 | Interrupt control register | TAA7OVIC  | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF196 | Interrupt control register | TAA7CCIC0 | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF198 | Interrupt control register | TAA7CCIC1 | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF19A | Interrupt control register | TAA8OVIC  | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF19C | Interrupt control register | TAA8CCIC0 | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF19E | Interrupt control register | TAA8CCIC1 | R/W | R/W | -  |    | 0x47            |
| 0xFFFFF1A0 | Interrupt control register | TAA9OVIC  | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF1A2 | Interrupt control register | TAA9CCIC0 | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF1A4 | Interrupt control register | TAA9CCIC1 | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF1A6 | Interrupt control register | BRGIC     | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF1A8 | Interrupt control register | BRGIC2    | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF1B6 | Interrupt control register | COERRIC   | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF1B8 | Interrupt control register | COWUPIC   | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF1BA | Interrupt control register | CORECIC   | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF1BC | Interrupt control register | COTRXIC   | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF1BE | Interrupt control register | C1ERRIC   | R/W | R/W | -  |    | 0x47            |
| 0xFFFFF1C0 | Interrupt control register | C1WUPIC   | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF1C2 | Interrupt control register | C1RECIC   | R/W | R/W | -  |    | 0x47            |
| 0xFFFFF1C4 | Interrupt control register | C1TRXIC   | R/W | R/W | -  |    | 0x47            |
| 0xFFFFF1D6 | Interrupt control register | CB0TIC    | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF1D8 | Interrupt control register | CB0RIC    | R/W | R/W | -  |    | 0x47            |
| 0xFFFFF1DA | Interrupt control register | CB0REIC   | R/W | R/W | -  |    | 0x47            |
| 0xFFFFF1DC | Interrupt control register | CB1TIC    | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF1DE | Interrupt control register | CB1RIC    | R/W | R/W | -  |    | 0x47            |
| 0xFFFFF1E0 | Interrupt control register | CB1REIC   | R/W | R/W | -  |    | 0x47            |
| 0xFFFFF1E2 | Interrupt control register | CE00FIC   | R/W | R/W | -  |    | 0x47            |
| 0xFFFFF1E4 | Interrupt control register | CE0CIC    | R/W | R/W | -  |    | 0x47            |
| 0xFFFFF1E6 | Interrupt control register | CE10FIC   | R/W | R/W | -  | -  | 0x47            |



#### Table A-4 Other special function registers (4/15)

| Address    | Register name                            | Shortcut | 1   | 8   | 16 | 32 | Inital<br>value |
|------------|------------------------------------------|----------|-----|-----|----|----|-----------------|
| 0xFFFFF1E8 | Interrupt control register               | CE1CIC   | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF1EA | Interrupt control register               | UCOREIC  | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF1EC | Interrupt control register               | UC0TIC   | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF1EE | Interrupt control register               | UC1REIC  | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF1F0 | Interrupt control register               | UC1TIC   | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF1F2 | Interrupt control register               | ADIC0    | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF1F4 | Interrupt control register               | ADIC1    | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF1F6 | Interrupt control register               | DMAIC2   | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF1F8 | Interrupt control register               | DMAIC3   | R/W | R/W | -  | -  | 0x47            |
| 0xFFFFF1FA | In-service priority register             | ISPR     | R   | R   | -  | -  | 0x00            |
| 0xFFFFF1FC | Command register                         | PRCMD    | -   | W   | -  | -  | undefined       |
| 0xFFFFF200 | A/D Converter 0 mode register 0          | ADM00    | R/W | R/W | -  | -  | 0x00            |
| 0xFFFFF201 | A/D Converter 0 mode register 1          | ADM01    | R/W | R/W | -  | -  | 0x00            |
| 0xFFFFF202 | A/D Converter 0 mode register 2          | ADM02    | R/W | R/W | -  | -  | 0x00            |
| 0xFFFFF210 | A/D conversion result register 00        | ADCR00   | -   | -   | R  | -  | undefined       |
| 0xFFFFF211 | A/D conversion result register 00H       | ADCR00H  | -   | R   | -  | -  | undefined       |
| 0xFFFFF212 | A/D conversion result register 01        | ADCR01   | -   | -   | R  | -  | undefined       |
| 0xFFFFF213 | A/D conversion result register 01H       | ADCR01H  | -   | R   | -  | -  | undefined       |
| 0xFFFFF214 | A/D conversion result register 02        | ADCR02   | -   | -   | R  | -  | undefined       |
| 0xFFFFF215 | A/D conversion result register 02H       | ADCR02H  | -   | R   | -  | -  | undefined       |
| 0xFFFFF216 | A/D conversion result register 03        | ADCR03   | -   | -   | R  | -  | undefined       |
| 0xFFFFF217 | A/D conversion result register 03H       | ADCR03H  | -   | R   | -  | -  | undefined       |
| 0xFFFFF218 | A/D conversion result register 04        | ADCR04   | -   | -   | R  | -  | undefined       |
| 0xFFFFF219 | A/D conversion result register 04H       | ADCR04H  | -   | R   | -  | -  | undefined       |
| 0xFFFFF21A | A/D conversion result register 05        | ADCR05   | -   | -   | R  | -  | undefined       |
| 0xFFFFF21B | A/D conversion result register 05H       | ADCR05H  | -   | R   | -  | -  | undefined       |
| 0xFFFFF21C | A/D conversion result register 06        | ADCR06   | -   | -   | R  | -  | undefined       |
| 0xFFFFF21D | A/D conversion result register 06H       | ADCR06H  | -   | R   | -  | -  | undefined       |
| 0xFFFFF21E | A/D conversion result register 07        | ADCR07   | -   | -   | R  | -  | undefined       |
| 0xFFFFF21F | A/D conversion result register 07H       | ADCR07H  | -   | R   | -  | -  | undefined       |
| 0xFFFFF220 | A/D conversion result register 08        | ADCR08   | -   | -   | R  | -  | undefined       |
| 0xFFFFF221 | A/D conversion result register 08H       | ADCR08H  | -   | R   |    | -  | undefined       |
| 0xFFFFF222 | A/D conversion result register 09        | ADCR09   | -   | -   | R  | -  | undefined       |
| 0xFFFFF223 | A/D conversion result register 09H       | ADCR09H  | -   | R   | -  | -  | undefined       |
| 0xFFFFF22E | A/D conversion result register 0 for DMA | ADDMA0   | -   | -   | R  | -  | undefined       |
| 0xFFFFF240 | A/D Converter 1 mode register 0          | ADM10    | R/W | R/W | -  | -  | 0x00            |
| 0xFFFFF241 | A/D Converter 1 mode register 1          | ADM11    | R/W | R/W | -  | -  | 0x00            |
| 0xFFFFF242 | A/D Converter 1 mode register 2          | ADM12    | R/W | R/W | -  | -  | 0x00            |
| 0xFFFFF250 | A/D conversion result register 10        | ADCR10   | -   | -   | R  | -  | undefined       |
| 0xFFFFF251 | A/D conversion result register 10H       | ADCR10H  | -   | R   | -  | -  | undefined       |
| 0xFFFFF252 | A/D conversion result register 11        | ADCR11   | -   | -   | R  | -  | undefined       |



#### Table A-4 Other special function registers (5/15)

| Address    | Register name                                  | Shortcut | 1   | 8   | 16  | 32 | Inital<br>value |
|------------|------------------------------------------------|----------|-----|-----|-----|----|-----------------|
| 0xFFFFF253 | A/D conversion result register 11H             | ADCR11H  | •   | R   |     | -  | undefined       |
| 0xFFFFF254 | A/D conversion result register 12              | ADCR12   | -   | -   | R   | -  | undefined       |
| 0xFFFFF255 | A/D conversion result register 12H             | ADCR12H  | -   | R   | -   | -  | undefined       |
| 0xFFFFF256 | A/D conversion result register 13              | ADCR13   | -   | -   | R   | -  | undefined       |
| 0xFFFFF257 | A/D conversion result register 13H             | ADCR13H  | -   | R   | -   | -  | undefined       |
| 0xFFFFF258 | A/D conversion result register 14              | ADCR14   | -   | -   | R   | -  | undefined       |
| 0xFFFFF259 | A/D conversion result register 14H             | ADCR14H  | -   | R   | -   | -  | undefined       |
| 0xFFFFF25A | A/D conversion result register 15              | ADCR15   | -   | -   | R   | -  | undefined       |
| 0xFFFFF25B | A/D conversion result register 15H             | ADCR15H  | -   | R   | -   | -  | undefined       |
| 0xFFFFF25C | A/D conversion result register 16              | ADCR16   | -   | -   | R   | -  | undefined       |
| 0xFFFFF25D | A/D conversion result register 16H             | ADCR16H  | -   | R   | -   | -  | undefined       |
| 0xFFFFF25E | A/D conversion result register 17              | ADCR17   | -   | -   | R   | -  | undefined       |
| 0xFFFFF25F | A/D conversion result register 17H             | ADCR17H  | -   | R   | -   | -  | undefined       |
| 0xFFFFF260 | A/D conversion result register 18              | ADCR18   | -   | -   | R   | -  | undefined       |
| 0xFFFFF261 | A/D conversion result register 18H             | ADCR18H  | -   | R   | -   | -  | undefined       |
| 0xFFFFF262 | A/D conversion result register 19              | ADCR19   | -   | -   | R   | -  | undefined       |
| 0xFFFFF263 | A/D conversion result register 19H             | ADCR19H  | -   | R   | -   | -  | undefined       |
| 0xFFFFF26E | A/D conversion result register 1 for DMA       | ADDMA1   | -   | -   | R   | -  | undefined       |
| 0xFFFFF270 | A/D Converter 0 trigger source select register | ADTRSEL0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF272 | A/D Converter 1 trigger source select register | ADTRSEL1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF300 | DMA transfer memory start address register 0   | MAR0     | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF302 | DMA transfer memory start address register 1   | MAR1     | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF304 | DMA transfer memory start address register 2   | MAR2     | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF306 | DMA transfer memory start address register 3   | MAR3     | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF308 | DMA transfer memory start address register 4   | MAR4     | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF30A | DMA transfer memory start address register 5   | MAR5     | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF30C | DMA transfer memory start address register 6   | MAR6     | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF30E | DMA transfer memory start address register 7   | MAR7     | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF324 | DMA transfer SFR start address register 2      | SAR2     | -   | R/W | -   | -  | 0x00            |
| 0xFFFFF326 | DMA transfer SFR start address register 3      | SAR3     | -   | R/W | -   | -  | 0x00            |
| 0xFFFFF340 | DMA transfer count register 0                  | DTCR0    | -   | R/W | -   | -  | 0x00            |
| 0xFFFFF342 | DMA transfer count register 1                  | DTCR1    | -   | R/W | -   | -  | 0x00            |
| 0xFFFFF344 | DMA transfer count register 2                  | DTCR2    | -   | R/W | -   | -  | 0x00            |
| 0xFFFFF346 | DMA transfer count register 3                  | DTCR3    | -   | R/W | -   | -  | 0x00            |
| 0xFFFFF348 | DMA transfer count register 4                  | DTCR4    | -   | R/W | -   | -  | 0x00            |
| 0xFFFFF34A | DMA transfer count register 5                  | DTCR5    | -   | R/W | -   | -  | 0x00            |
| 0xFFFFF34C | DMA transfer count register 6                  | DTCR6    | -   | R/W | -   | -  | 0x00            |
| 0xFFFFF34E | DMA transfer count register 7                  | DTCR7    | -   | R/W | -   | -  | 0x00            |
| 0xFFFFF360 | DMA mode control register                      | DMAMCL   | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF362 | DMA status register                            | DMASL    | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF364 | DMA data size control register                 | DMADSCL  | R/W | R/W | -   | -  | 0x00            |



| Address    | Register name                    | Shortcut | 1   | 8   | 16 | 32 | Inital<br>value |
|------------|----------------------------------|----------|-----|-----|----|----|-----------------|
| 0xFFFFF388 | DMA trigger factor register 4    | DTFR4    | ·   | R/W | -  | -  | 0x00            |
| 0xFFFFF38A | DMA trigger factor register 5    | DTFR5    | -   | R/W | -  | -  | 0x00            |
| 0xFFFFF38C | DMA trigger factor register 6    | DTFR6    | -   | R/W | -  | -  | 0x00            |
| 0xFFFFF38E | DMA trigger factor register 7    | DTFR7    | -   | R/W | -  | -  | 0x00            |
| 0xFFFFF400 | Port 0                           | P0       | R   | R   | -  | -  | undefined       |
| 0xFFFFF402 | Port 1                           | P1       | R/W | R/W | -  | -  | undefined       |
| 0xFFFFF404 | Port 2                           | P2       | R/W | R/W | -  | -  | undefined       |
| 0xFFFFF406 | Port 3                           | P3       | R/W | R/W | -  | -  | undefined       |
| 0xFFFFF408 | Port 4                           | P4       | R/W | R/W | -  | -  | undefined       |
| 0xFFFFF40A | Port 5                           | P5       | R/W | R/W | -  | -  | undefined       |
| 0xFFFFF40C | Port 6                           | P6       | R/W | R/W | -  | -  | undefined       |
| 0xFFFFF40E | Port 7                           | P7       | R/W | R/W | -  | -  | undefined       |
| 0xFFFFF410 | Port 8                           | P8       | R/W | R/W | -  | -  | undefined       |
| 0xFFFFF412 | Port 9                           | P9       | R/W | R/W | -  | -  | undefined       |
| 0xFFFFF414 | Port 10                          | P10      | R/W | R/W | -  | -  | undefined       |
| 0xFFFFF416 | Port 11                          | P11      | R/W | R/W | -  | -  | undefined       |
| 0xFFFFF422 | Port 1 mode                      | PM1      | R/W | R/W | -  | -  | 0xFF            |
| 0xFFFFF424 | Port 2 mode                      | PM2      | R/W | R/W | -  | -  | 0xFF            |
| 0xFFFFF426 | Port 3 mode                      | PM3      | R/W | R/W | -  | -  | 0xFF            |
| 0xFFFFF428 | Port 4 mode                      | PM4      | R/W | R/W | -  | -  | 0xFF            |
| 0xFFFFF42A | Port 5 mode                      | PM5      | R/W | R/W | -  | -  | 0xFF            |
| 0xFFFFF42C | Port 6 mode                      | PM6      | R/W | R/W | -  | -  | 0xFF            |
| 0xFFFFF42E | Port 7 mode                      | PM7      | R/W | R/W | -  | -  | 0xFF            |
| 0xFFFFF430 | Port 8 mode                      | PM8      | R/W | R/W | -  | -  | 0xFF            |
| 0xFFFFF432 | Port 9 mode                      | PM9      | R/W | R/W | -  | -  | 0xFF            |
| 0xFFFFF434 | Port 10 mode                     | PM10     | R/W | R/W | -  | -  | 0xFF            |
| 0xFFFFF436 | Port 11 mode                     | PM11     | R/W | R/W | -  | -  | 0xFF            |
| 0xFFFFF442 | Port 1 mode control              | PMC1     | R/W | R/W | -  | -  | 0x00            |
| 0xFFFFF444 | Port 2 mode control              | PMC2     | R/W | R/W | -  | -  | 0x00            |
| 0xFFFFF446 | Port 3 mode control              | PMC3     | R/W | R/W | -  | -  | 0x00            |
| 0xFFFFF448 | Port 4 mode control              | PMC4     | R/W | R/W | -  | -  | 0x00            |
| 0xFFFFF44A | Port 5 mode control              | PMC5     | R/W | R/W | -  | -  | 0x00            |
| 0xFFFFF44C | Port 6mode control               | PMC6     | R/W | R/W | -  | -  | 0x00            |
| 0xFFFFF44E | Port 7 mode control              | PMC7     | R/W | R/W | -  | -  | 0x00            |
| 0xFFFFF450 | Port 8 mode control              | PMC8     | R/W | R/W | -  | -  | 0x00            |
| 0xFFFFF452 | Port 9 mode control              | PMC9     | R/W | R/W | -  | -  | 0x00            |
| 0xFFFFF454 | Port 10 mode control             | PMC10    | R/W | R/W | -  | -  | 0x00            |
| 0xFFFFF456 | Port 11 mode control             | PMC11    | R/W | R/W | -  | -  | 0x00            |
| 0xFFFFF462 | Port 1 function control register | PFC1     | R/W | R/W | -  | -  | 0x00            |
| 0xFFFFF464 | Port 2 function control register | PFC2     | R/W | R/W | -  | -  | 0x00            |
| 0xFFFFF46E | Port 7 function control register | PFC7     | R/W | R/W | -  | -  | 0x00            |

#### Table A-4 Other special function registers (6/15)



#### Table A-4 Other special function registers (7/15)

| Address    | Register name                                 | Shortcut | 1   | 8   | 16  | 32 | Inital<br>value |
|------------|-----------------------------------------------|----------|-----|-----|-----|----|-----------------|
| 0xFFFFF470 | Port 8 function control register              | PFC8     | R/W | R/W | -   | •  | 0x00            |
| 0xFFFFF472 | Port 9 function control register              | PFC9     | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF474 | Port 10 function control register             | PFC10    | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF480 | Bus cycle configuration register 0            | BCT0     | -   | -   | R/W | -  | 0x4444          |
| 0xFFFFF482 | Bus cycle configuration register 1            | BCT1     | -   | -   | R/W | -  | 0x4444          |
| 0xFFFFF484 | Data wait control register 0                  | DWC0     | -   | -   | R/W | -  | 0x7777          |
| 0xFFFFF486 | Data wait control register 1                  | DWC1     | -   | -   | R/W | -  | 0x7777          |
| 0xFFFFF488 | Address wait control register                 | AWC      | -   | -   | R/W | -  | 0xFFFF          |
| 0xFFFFF48A | Bus cycle control register                    | BCC      | -   | -   | R/W | -  | 0xAAAA          |
| 0xFFFFF48E | Bus clock dividing frequency control register | DVC      | -   | R/W | -   | -  | 0x00            |
| 0xFFFFF580 | TMS0 control register 0                       | TS0CTL0  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF581 | TMS0 control register 1                       | TS0CTL1  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF582 | TMS0 I/O control register 0                   | TS0IOC0  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF582 | TMS0 I/O control register 0L                  | TS0IOC0L | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF583 | TMS0 I/O control register 0H                  | TS0IOC0H | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF584 | TMS0 I/O control register 0                   | TS0IOC2  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF585 | TMS0 I/O control register 0                   | TS0IOC4  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF586 | TMS0 option register 0                        | TS0OPT0  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF587 | TMS0 option register 7                        | TS0OPT7  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF588 | TMS0 option register 4                        | TS0OPT4  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF589 | TMS0 option register 5                        | TS0OPT5  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF58A | TMS0 option register 1                        | TS0OPT1  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF58A | TMS0 option register 1L                       | TS0OPT1L | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF58B | TMS0 option register 1H                       | TS0OPT1H | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF58C | TMS0 dead time setting register 1             | TS0DTC1  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF58E | TMS0 dead time setting register 0             | TS0DTC0  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF590 | TMS0 compare register 5                       | TS0CCR5  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF592 | TMS0 compare register 4                       | TS0CCR4  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF594 | TMS0 pattern register 1                       | TS0PAT1  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF596 | TMS0 pattern register 0                       | TS0PAT0  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF598 | TMS0 compare register 0                       | TS0CCR0  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF59A | TMS0 compare register 3                       | TS0CCR3  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF59C | TMS0 compare register 2                       | TS0CCR2  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF59E | TMS0 compare register 1                       | TS0CCR1  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF5A0 | TMS0 option register 2                        | TS0OPT2  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF5A0 | TMS0 option register 2L                       | TS0OPT2L | R/W | R/W | -   |    | 0x00            |
| 0xFFFFF5A1 | TMS0 option register 2H                       | TS0OPT2H | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5A2 | TMS0 option register 3                        | TS0OPT3  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF5A2 | TMS0 option register 3L                       | TS0OPT3L | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5A3 | TMS0 option register 3H                       | TS0OPT3H | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5A4 | TMS0 option register 6                        | TS0OPT6  | -   | -   | R/W | -  | 0x0000          |



#### Table A-4 Other special function registers (8/15)

| Address    | Register name                     | Shortcut | 1   | 8   | 16  | 32 | Inital<br>value |
|------------|-----------------------------------|----------|-----|-----|-----|----|-----------------|
| 0xFFFFF5A4 | TMS0 option register 6L           | TS0OPT6L | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5A5 | TMS0 option register 6H           | TS0OPT6H | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5A6 | TMS0 counter read register        | TS0CNT   | -   | -   | R   | -  | 0x0000          |
| 0xFFFFF5A8 | TMS0 sub-counter read register    | TS0SBC   | -   | -   | R   | -  | 0x0000          |
| 0xFFFFF5C0 | TMS1 control register 0           | TS1CTL0  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5C1 | TMS1 control register 1           | TS1CTL1  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5C2 | TMS1 I/O control register 0       | TS1IOC0  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF5C2 | TMS1 I/O control register 0L      | TS1IOC0L | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5C3 | TMS1 I/O control register 0H      | TS1IOC0H | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5C4 | TMS1 I/O control register 0       | TS1IOC2  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5C5 | TMS1 I/O control register 0       | TS1IOC4  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5C6 | TMS1 option register 0            | TS1OPT0  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5C7 | TMS1 option register 7            | TS1OPT7  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5C8 | TMS1 option register 4            | TS1OPT4  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5C9 | TMS1 option register 5            | TS1OPT5  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5CA | TMS1 option register 1            | TS1OPT1  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF5CA | TMS1 option register 1L           | TS1OPT1L | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5CB | TMS1 option register 1H           | TS1OPT1H | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5CC | TMS1 dead time setting register 1 | TS1DTC1  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF5CE | TMS1 dead time setting register 0 | TS1DTC0  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF5D0 | TMS1 compare register 5           | TS1CCR5  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF5D2 | TMS1 compare register 4           | TS1CCR4  |     | -   | R/W | -  | 0x0000          |
| 0xFFFFF5D4 | TMS1 pattern register 1           | TS1PAT1  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF5D6 | TMS1 pattern register 0           | TS1PAT0  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF5D8 | TMS1 compare register 0           | TS1CCR0  |     | -   | R/W | -  | 0x0000          |
| 0xFFFFF5DA | TMS1 compare register 3           | TS1CCR3  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF5DC | TMS1 compare register 2           | TS1CCR2  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF5DE | TMS1 compare register 1           | TS1CCR1  |     | -   | R/W | -  | 0x0000          |
| 0xFFFFF5E0 | TMS1 option register 2            | TS1OPT2  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF5E0 | TMS1 option register 2L           | TS10PT2L | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5E1 | TMS1 option register 2H           | TS10PT2H | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5E2 | TMS1 option register 3            | TS1OPT3  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF5E2 | TMS1 option register 3L           | TS10PT3L | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5E3 | TMS1 option register 3H           | TS1OPT3H | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5E4 | TMS1 option register 6            | TS1OPT6  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF5E4 | TMS1 option register 6L           | TS1OPT6L | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5E5 | TMS1 option register 6H           | TS1OPT6H | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF5E6 | TMS1 counter read register        | TS1CNT   | -   | -   | R   | -  | 0x0000          |
| 0xFFFFF5E8 | TMS1 sub-counter read register    | TS1SBC   | -   | -   | R   | -  | 0x0000          |
| 0xFFFFF600 | TAA0 control register 0           | TAA0CTL0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF601 | TAA0 control register 1           | TAA0CTL1 | R/W | R/W | -   | -  | 0x00            |



#### Table A-4 Other special function registers (9/15)

| Address    | Register name                                 | Shortcut | 1   | 8   | 16  | 32 | Inital<br>value |
|------------|-----------------------------------------------|----------|-----|-----|-----|----|-----------------|
| 0xFFFFF602 | TAA0 I/O control register 0                   | TAA0IOC0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF603 | TAA0 I/O control register 1                   | TAA0IOC1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF604 | TAA0 I/O control register 2                   | TAA0IOC2 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF605 | TAA0 option register 0                        | TAA0OPT0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF606 | TAA0 capture/compare register 0               | TAA0CCR0 | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF608 | TAA0 capture/compare register 1               | TAA0CCR1 | -   | -   | R/W | -  | 0x0000          |
| 0xFFFF60A  | TAA0 counter read buffer register             | TAA0CNT  | -   | -   | R   | -  | 0x0000          |
| 0xFFFFF60C | TAA0 I/O control register 4                   | TAA0IOC4 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF60E | TAA0 specific overflow value control register | TAA0SVC  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF610 | TAA1 control register 0                       | TAA1CTL0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF611 | TAA1 control register 1                       | TAA1CTL1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF612 | TAA1 I/O control register 0                   | TAA1IOC0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF613 | TAA1 I/O control register 1                   | TAA1IOC1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF614 | TAA1 I/O control register 2                   | TAA1IOC2 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF615 | TAA1 option register 0                        | TAA1OPT0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF616 | TAA1 capture/compare register 0               | TAA1CCR0 | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF618 | TAA1 capture/compare register 1               | TAA1CCR1 | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF61A | TAA1 counter read buffer register             | TAA1CNT  | -   | -   | R   | -  | 0x0000          |
| 0xFFFFF61C | TAA1 I/O control register 4                   | TAA1IOC4 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF61D | TAA1 option register 1                        | TAA1OPT1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF61E | TAA1 specific overflow value control register | TAA1SVC  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF620 | TAA2 control register 0                       | TAA2CTL0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF621 | TAA2 control register 1                       | TAA2CTL1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF622 | TAA2 I/O control register 0                   | TAA2IOC0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF623 | TAA2 I/O control register 1                   | TAA2IOC1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF624 | TAA2 I/O control register 2                   | TAA2IOC2 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF625 | TAA2 option register 0                        | TAA2OPT0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF626 | TAA2 capture/compare register 0               | TAA2CCR0 | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF628 | TAA2 capture/compare register 1               | TAA2CCR1 | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF62A | TAA2 counter read buffer register             | TAA2CNT  | -   | -   | R   | -  | 0x0000          |
| 0xFFFFF62C | TAA2 I/O control register 4                   | TAA2IOC4 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF62D | TAA2 option register 1                        | TAA2OPT1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF62E | TAA2 specific overflow value control register | TAA2SVC  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF630 | TAA3 control register 0                       | TAA3CTL0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF631 | TAA3 control register 1                       | TAA3CTL1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF632 | TAA3 I/O control register 0                   | TAA3IOC0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF633 | TAA3 I/O control register 1                   | TAA3IOC1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF634 | TAA3 I/O control register 2                   | TAA3IOC2 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF635 | TAA3 option register 0                        | TAA3OPT0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF636 | TAA3 capture/compare register 0               | TAA3CCR0 | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF638 | TAA3 capture/compare register 1               | TAA3CCR1 | -   | -   | R/W | -  | 0x0000          |



| Address    | Register name                                 | Shortcut | 1   | 8   | 16  | 32 | Inital<br>value |
|------------|-----------------------------------------------|----------|-----|-----|-----|----|-----------------|
| 0xFFFFF63A | TAA3 counter read buffer register             | TAA3CNT  | •   | -   | R   | -  | 0x0000          |
| 0xFFFFF63C | TAA3 I/O control register 4                   | TAA3IOC4 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF63D | TAA3 option register 1                        | TAA3OPT1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF63E | TAA3 specific overflow value control register | TAA3SVC  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF640 | TAA4 control register 0                       | TAA4CTL0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF641 | TAA4 control register 1                       | TAA4CTL1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF642 | TAA4 I/O control register 0                   | TAA4IOC0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF643 | TAA4 I/O control register 1                   | TAA4IOC1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF644 | TAA4 I/O control register 2                   | TAA4IOC2 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF645 | TAA4 option register 0                        | TAA4OPT0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF646 | TAA4 capture/compare register 0               | TAA4CCR0 | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF648 | TAA4 capture/compare register 1               | TAA4CCR1 |     | -   | R/W | -  | 0x0000          |
| 0xFFFFF64A | TAA4 counter read buffer register             | TAA4CNT  |     | -   | R   | -  | 0x0000          |
| 0xFFFFF64C | TAA4 I/O control register 4                   | TAA4IOC4 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF64E | TAA4 specific overflow value control register | TAA4SVC  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF650 | TAA5 control register 0                       | TAA5CTL0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF651 | TAA5 ontrol register 1                        | TAA5CTL1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF652 | TAA5 I/O control register 0                   | TAA5IOC0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF653 | TAA5 I/O control register 1                   | TAA5IOC1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF654 | TAA5 I/O control register 2                   | TAA5IOC2 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF655 | TAA5 option register 0                        | TAA5OPT0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF656 | TAA5 capture/compare register 0               | TAA5CCR0 |     | -   | R/W | -  | 0x0000          |
| 0xFFFFF658 | TAA5 capture/compare register 1               | TAA5CCR1 |     | -   | R/W | -  | 0x0000          |
| 0xFFFFF65A | TAA5 counter read buffer register             | TAA5CNT  | -   | -   | R   | -  | 0x0000          |
| 0xFFFFF65C | TAA5 I/O control register 4                   | TAA5IOC4 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF65D | TAA5 option register 1                        | TAA5OPT1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF65E | TAA5 specific overflow value control register | TAA5SVC  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF660 | TAA6 control register 0                       | TAA6CTL0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF661 | TAA6 control register 1                       | TAA6CTL1 | R/W | R/W | -   | •  | 0x00            |
| 0xFFFFF662 | TAA6 I/O control register 0                   | TAA6IOC0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF663 | TAA6 I/O control register 1                   | TAA6IOC1 | R/W | R/W | -   | •  | 0x00            |
| 0xFFFFF664 | TAA6 I/O control register 2                   | TAA6IOC2 | R/W | R/W | -   | •  | 0x00            |
| 0xFFFFF665 | TAA6 option register 0                        | TAA6OPT0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF666 | TAA6 capture/compare register 0               | TAA6CCR0 | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF668 | TAA6 capture/compare register 1               | TAA6CCR1 | •   | -   | R/W | •  | 0x0000          |
| 0xFFFFF66A | TAA6 counter read buffer register             | TAA6CNT  | -   | -   | R   | •  | 0x0000          |
| 0xFFFFF66C | TAA6 I/O control register 4                   | TAA6IOC4 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF66D | TAA6 option register 1                        | TAA6OPT1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF66E | TAA6 specific overflow value control register | TAA6SVC  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF670 | TAA7 control register 0                       | TAA7CTL0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF671 | TAA7 control register 1                       | TAA7CTL1 | R/W | R/W | -   | -  | 0x00            |

 Table A-4
 Other special function registers (10/15)



#### Table A-4 Other special function registers (11/15)

| Address    | Register name                                 | Shortcut | 1   | 8   | 16  | 32 | Inital<br>value |
|------------|-----------------------------------------------|----------|-----|-----|-----|----|-----------------|
| 0xFFFFF672 | TAA7 I/O control register 0                   | TAA7IOC0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF673 | TAA7 I/O control register 1                   | TAA7IOC1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF674 | TAA7 I/O control register 2                   | TAA7IOC2 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF675 | TAA7 option register 0                        | TAA7OPT0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF676 | TAA7 capture/compare register 0               | TAA7CCR0 | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF678 | TAA7 capture/compare register 1               | TAA7CCR1 | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF67A | TAA7 counter read buffer register             | TAA7CNT  | -   | -   | R   | -  | 0x0000          |
| 0xFFFF67C  | TAA7 I/O control register 4                   | TAA7IOC4 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF67D | TAA7 option register 1                        | TAA7OPT1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF67E | TAA7 specific overflow value control register | TAA7SVC  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF680 | TAA8 control register 0                       | TAA8CTL0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF681 | TAA8 control register 1                       | TAA8CTL1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF682 | TAA8 I/O control register 0                   | TAA8IOC0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF683 | TAA8 I/O control register 1                   | TAA8IOC1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF684 | TAA8 I/O control register 2                   | TAA8IOC2 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF685 | TAA8 option register 0                        | TAA8OPT0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF686 | TAA8 capture/compare register 0               | TAA8CCR0 | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF688 | TAA8 capture/compare register 1               | TAA8CCR1 | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF68A | TAA8 counter read buffer register             | TAA8CNT  | -   | -   | R   | -  | 0x0000          |
| 0xFFFF68C  | TAA8 I/O control register 4                   | TAA8IOC4 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF68E | TAA8 specific overflow value control register | TAA8SVC  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF690 | TMT0 control register 0                       | TTOCTLO  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF691 | TMT0 control register 1                       | TT0CTL1  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF692 | TMT0 control register 2                       | TT0CTL2  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF693 | TMT0 I/O control register 0                   | TT0IOC0  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF694 | TMT0 I/O control register 1                   | TT0IOC1  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF695 | TMT0 I/O control register 2                   | TT0IOC2  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF696 | TMT0 I/O control register 3                   | TT0IOC3  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF697 | TMT0 option register 0                        | TT0OPT0  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF698 | TMT0 option register 1                        | TT0OPT1  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF699 | TMT0 option register 2                        | TT0OPT2  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF69A | TMT0 capture/compare register 0               | TT0CCR0  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF69C | TMT0 capture/compare register 1               | TT0CCR1  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF69E | TMT0 counter read buffer register             | TTOCNT   | -   | -   | R   |    | 0x0000          |
| 0xFFFFF6A0 | TMT1 control register 0                       | TT1CTL0  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF6A1 | TMT1 control register 1                       | TT1CTL1  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF6A2 | TMT1 control register 2                       | TT1CTL2  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF6A3 | TMT1 I/O control register 0                   | TT1IOC0  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF6A4 | TMT1 I/O control register 1                   | TT1IOC1  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF6A5 | TMT1 I/O control register 2                   | TT1IOC2  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF6A6 | TMT1 I/O control register 3                   | TT1IOC3  | R/W | R/W | -   | -  | 0x00            |



#### Table A-4 Other special function registers (12/15)

| Address    | Register name                                  | Shortcut | 1   | 8   | 16  | 32 | Inital<br>value |
|------------|------------------------------------------------|----------|-----|-----|-----|----|-----------------|
| 0xFFFFF6A7 | TMT1 option register 0                         | TT1OPT0  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF6A8 | TMT1 option register 1                         | TT1OPT1  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF6A9 | TMT1 option register 2                         | TT1OPT2  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF6AA | TMT1 capture/compare register 0                | TT1CCR0  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF6AC | TMT1 capture/compare register 1                | TT1CCR1  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF6AE | TMT1 counter read buffer register              | TT1CNT   | -   | -   | R   | -  | 0x0000          |
| 0xFFFF6B0  | TAA9 control register 0                        | TAA9CTL0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFF6B1  | TAA9 control register 1                        | TAA9CTL1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF6B2 | TAA9 I/O control register 0                    | TAA9IOC0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF6B3 | TAA9 I/O control register 1                    | TAA9IOC1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFF6B4  | TAA9 I/O control register 2                    | TAA9IOC2 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFF6B5  | TAA9 option register 0                         | TAA9OPT0 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFF6B6  | TAA9 capture/compare register 0                | TAA9CCR0 | -   | -   | R/W | -  | 0x0000          |
| 0xFFFF6B8  | TAA9 capture/compare register 1                | TAA9CCR1 | -   | -   | R/W | -  | 0x0000          |
| 0xFFFF6BA  | TAA9 counter read buffer register              | TAA9CNT  | -   | -   | R   | -  | 0x0000          |
| 0xFFFFF6BC | TAA9 I/O control register 3                    | TAA9IOC4 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFF6BD  | TAA9 option register 1                         | TAA9OPT1 | R/W | R/W | -   | -  | 0x00            |
| 0xFFFF6BE  | TAA9 specific overflow value control register  | TAA9SVC  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF6D0 | Interrupt share enable register                | INTSEL   | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF6D2 | Interrupt source flag register                 | INTERRF  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF6F0 | Timer input control register 0                 | TAAIC0   | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF6F1 | Timer input control register 1                 | TAAIC1   | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF6F2 | Timer input control register 2                 | TAAIC2   | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF6F3 | Timer input control register 3                 | TAAIC3   | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF7A0 | Noise rejection time control register          | NRC      | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF802 | Peripheral status register                     | PHS      | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF860 | CAN clock selection register                   | CANCKSEL | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF880 | External interrupt edge specification register | INTM0    | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF882 | External interrupt edge specification register | INTM1    | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF884 | External interrupt edge specification register | INTM2    | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF886 | External interrupt edge specification register | INTM3    | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF888 | Emergency shut-off control register 5          | PESC5    | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF88A | Emergency shut-off status register 5           | ESOST5   | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF88C | Emergency shut-off control register 6          | PESC6    | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF88E | Emergency shut-off status register 6           | ESOST6   | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF890 | Emergency shut-off mask register 5             | PESMK5   | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF892 | Emergency shut-off mask register 6             | PESMK6   | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF8A0 | Flash ROM ECC error register                   | ROMEAD   | -   | -   | -   | R  | 0x0000000       |
| 0xFFFF8B0  | RAM ECC error register                         | RAMEAD   | -   | -   | R   | -  | 0x0000          |
| 0xFFFF8B0  | RAM ECC error address register                 | RAMEAD   | -   | -   | R   | -  | 0x0000          |
| 0xFFFFF8B2 | RAM ECC data location register                 | RAMEDLR  |     | R   | -   | -  | 0x00            |



#### Table A-4 Other special function registers (13/15)

| Address    | Register name                      | Shortcut  | 1   | 8   | 16  | 32 | Inital<br>value |
|------------|------------------------------------|-----------|-----|-----|-----|----|-----------------|
| 0xFFFFF8B4 | RAM ECC control register           | RAMECC    | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFF990 | TMT0 counter write buffer register | TTOTCW    | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFF9A0 | TMT1 counter write buffer register | TT1TCW    | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFA00 | UARTC0 control register 0          | UC0CTL0   | R/W | R/W | -   | -  | 0x10            |
| 0xFFFFFA01 | UARTC0 control register 1          | UC0CTL1   | -   | R/W | -   | -  | 0x00            |
| 0xFFFFFA02 | UARTC0 control register 2          | UC0CTL2   | -   | R/W | -   | -  | 0xFF            |
| 0xFFFFFA03 | UARTC0 option control register 0   | UC0OPT0   | R/W | R/W | -   | -  | 0x14            |
| 0xFFFFFA04 | UARTC0 status register             | UC0STR    | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFA06 | UARTC0 receive data register       | UCORX     | -   | -   | R   | -  | 0x01FF          |
| 0xFFFFFA06 | UARTC0 receive data register L     | UCORXL    | -   | R   | -   | -  | 0xFF            |
| 0xFFFFFA08 | UARTC0 transmit data register      | UC0TX     | -   | -   | R/W | -  | 0x01FF          |
| 0xFFFFFA08 | UARTC0 transmit data register L    | UC0TXL    | -   | R/W | -   | -  | 0xFF            |
| 0xFFFFFA0A | UARTC0 option control register 1   | UC0OPT1   | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFA0B | UARTC0 option control register 2   | UC00PT2   | R   | R   | -   | -  | 0x00            |
| 0xFFFFFA20 | UARTC1 control register 0          | UC1CTL0   | R/W | R/W | -   | -  | 0x10            |
| 0xFFFFFA21 | UARTC1 control register 1          | UC1CTL1   | -   | R/W | -   | -  | 0x00            |
| 0xFFFFFA22 | UARTC1 control register 2          | UC1CTL2   | -   | R/W | -   | -  | 0xFF            |
| 0xFFFFFA23 | UARTC1 option control register 0   | UC1OPT0   | R/W | R/W | -   | -  | 0x14            |
| 0xFFFFFA24 | UARTC1 status register             | UC1STR    | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFA26 | UARTC1 receive data register       | UC1RX     | -   | -   | R   | -  | 0x01FF          |
| 0xFFFFFA26 | UARTC1 receive data register L     | UC1RXL    | -   | R   | -   | -  | 0xFF            |
| 0xFFFFFA28 | UARTC1 transmit data register      | UC1TX     | -   | -   | R/W | -  | 0x01FF          |
| 0xFFFFFA28 | UARTC1 transmit data register L    | UC1TXL    | -   | R/W | -   | -  | 0xFF            |
| 0xFFFFFA2A | UARTC1 option control register 1   | UC10PT1   | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFA2B | UARTC1 option control register 2   | UC1OPT2   | R   | R   | -   | -  | 0x00            |
| 0xFFFFFB40 | TMS0 option register 1A            | TS0OPT1A  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFB40 | TMS0 option register 1AL           | TS0OPT1AL | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFB41 | TMS0 option register 1AH           | TS0OPT1AH | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFB42 | TMS0 dead time setting register 1A | TS0DTC1A  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFB44 | TMS0 dead time setting register 0A | TS0DTC0A  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFB46 | TMS0 compare register 5A           | TS0CCR5A  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFB48 | TMS0 compare register 4A           | TS0CCR4A  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFB4A | TMS0 compare register 3B           | TS0CCR3B  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFB4C | TMS0 compare register 2B           | TS0CCR2B  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFB4E | TMS0 compare register 1B           | TS0CCR1B  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFB50 | TMS0 compare register 0A           | TS0CCR0A  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFB52 | TMS0 compare register 3A           | TS0CCR3A  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFB54 | TMS0 compare register 2A           | TS0CCR2A  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFB56 | TMS0 compare register 1A           | TS0CCR1A  |     |     | R/W | -  | 0x0000          |
| 0xFFFFBC0  | TMS1 option register 1A            | TS10PT1A  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFBC0 | TMS1 option register 1AL           | TS10PT1AL | R/W | R/W | -   | -  | 0x00            |



#### Table A-4 Other special function registers (14/15)

| Address    | Register name                              | Shortcut  | 1   | 8   | 16  | 32 | Inital<br>value |
|------------|--------------------------------------------|-----------|-----|-----|-----|----|-----------------|
| 0xFFFFFBC1 | TMS1 option register 1AH                   | TS10PT1AH | R/W | R/W | -   |    | 0x00            |
| 0xFFFFFBC2 | TMS1 dead time setting register 1A         | TS1DTC1A  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFBC4 | TMS1 dead time setting register 0A         | TS1DTC0A  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFBC6 | TMS1 compare register 5A                   | TS1CCR5A  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFBC8 | TMS1 compare register 4A                   | TS1CCR4A  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFBCA  | TMS1 compare register 3B                   | TS1CCR3B  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFBCC | TMS1 compare register 2B                   | TS1CCR2B  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFBCE  | TMS1 compare register 1B                   | TS1CCR1B  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFBD0  | TMS1 compare register 0A                   | TS1CCR0A  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFBD2 | TMS1 compare register 3A                   | TS1CCR3A  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFBD4  | TMS1 compare register 2A                   | TS1CCR2A  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFBD6 | TMS1 compare register 1A                   | TS1CCR1A  | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFC32 | Port 9 function control expansion register | PFCE9     | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFCA0 | Clock monitor mode register                | CLM       | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFCF8 | Data flash control register                | DFLCTL    | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFD00 | CSIB0 control register 0                   | CB0CTL0   | R/W | R/W | -   | -  | 0x01            |
| 0xFFFFFD01 | CSIB0 control register 1                   | CB0CTL1   | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFD02 | CSIB0 control register 2                   | CB0CTL2   | -   | R/W | -   | -  | 0x00            |
| 0xFFFFFD03 | CSIB0 status register                      | CB0STR    | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFD04 | CSIB0 receive data register                | CB0RX0    | -   | -   | R   | -  | 0x0000          |
| 0xFFFFFD04 | CSIB0 receive data register L              | CB0RX0L   | -   | R   | -   | -  | 0x00            |
| 0xFFFFFD06 | CSIB0 transmit data register               | CB0TX0    | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFD06 | CSIB0 transmit data register L             | CB0TX0L   | -   | R/W | -   | -  | 0x00            |
| 0xFFFFFD20 | CSIB1 control register 0                   | CB1CTL0   | R/W | R/W | -   | -  | 0x01            |
| 0xFFFFFD21 | CSIB1 control register 1                   | CB1CTL1   | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFD22 | CSIB1 control register 2                   | CB1CTL2   | -   | R/W | -   | -  | 0x00            |
| 0xFFFFFD23 | CSIB1 status register                      | CB1STR    | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFD24 | CSIB1 receive data register                | CB1RX0    | -   | -   | R   | -  | 0x0000          |
| 0xFFFFFD24 | CSIB1 receive data register L              | CB1RX0L   | -   | R   | -   | -  | 0x00            |
| 0xFFFFFD26 | CSIB1 transmit data register               | CB1TX0    | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFD26 | CSIB1 transmit data register L             | CB1TX0L   | -   | R/W | -   | -  | 0x00            |
| 0xFFFFFD40 | Queued CSI0 control register 0             | CE0CTL0   | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFD41 | Queued CSI0 control register 1             | CE0CTL1   | R/W | R/W | -   | -  | 0x07            |
| 0xFFFFFD42 | CSIE0 receive data register                | CE0RX0    | -   | -   | R   | -  | 0x0000          |
| 0xFFFFFD42 | CSIE0 receive data register L              | CE0RXL0   | -   | R   | -   | -  | 0x00            |
| 0xFFFFFD43 | CSIE0 receive data register H              | CE0RXH0   | -   | R   | -   | -  | 0x00            |
| 0xFFFFFD44 | CSIE0 chip select data buffer register     | CE0CS     | -   | R/W | R/W | -  | 0xFFFF          |
| 0xFFFFFD46 | CSIE0 transmission data buffer register    | CE0TX0    | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFD46 | CSIE0 transmission data buffer register L  | CE0TXL0   | -   | R/W | -   | -  | 0x00            |
| 0xFFFFFD47 | CSIE0 transmission data buffer register H  | CE0TXH0   | -   | R/W | -   | -  | 0x00            |
| 0xFFFFFD48 | Queued CSI0 status register                | CE0STR    | R/W | R/W | -   | -  | 0x20            |



#### Table A-4 Other special function registers (15/15)

| Address    | Register name                             | Shortcut | 1   | 8   | 16  | 32 | Inital<br>value |
|------------|-------------------------------------------|----------|-----|-----|-----|----|-----------------|
| 0xFFFFFD49 | Queued CSI0 control register 2            | CE0CTL2  | R/W | R/W | -   | •  | 0x00            |
| 0xFFFFFD4C | Queued CSI0 control register 3            | CE0CTL3  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFD4D | Queued CSI0 control register 4            | CE0CTL4  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFD50 | Queued CSI0 enhanced timing register 0    | CE0OPT0  | -   | -   | R/W | -  | 0x0002          |
| 0xFFFFFD52 | Queued CSI0 enhanced timing register 1    | CE00PT1  | -   | -   | R/W | -  | 0x0002          |
| 0xFFFFFD54 | Queued CSI0 enhanced timing register 2    | CE00PT2  | -   | -   | R/W | -  | 0x0002          |
| 0xFFFFFD56 | Queued CSI0 enhanced timing register 3    | CE00PT3  | -   | -   | R/W | -  | 0x0002          |
| 0xFFFFFD58 | Queued CSI0 enhanced timing register 4    | CE00PT4  | -   | -   | R/W | -  | 0x0002          |
| 0xFFFFFD5A | Queued CSI0 enhanced timing register 5    | CE00PT5  | -   | -   | R/W | -  | 0x0002          |
| 0xFFFFFD5C | Queued CSI0 enhanced timing register 6    | CE0OPT6  | -   | -   | R/W | -  | 0x0002          |
| 0xFFFFFD5E | Queued CSI0 enhanced timing register 7    | CE00PT7  | -   | -   | R/W | -  | 0x0002          |
| 0xFFFFFD80 | Queued CSI1 control register 0            | CE1CTL0  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFD81 | Queued CSI1 control register 1            | CE1CTL1  | R/W | R/W | -   | -  | 0x07            |
| 0xFFFFFD82 | CSIE1 receive data register               | CE1RX0   | -   | -   | R   | -  | 0x0000          |
| 0xFFFFFD82 | CSIE1 receive data register L             | CE1RXL0  | -   | R   | -   | -  | 0x00            |
| 0xFFFFFD83 | CSIE1 receive data register H             | CE1RXH0  | -   | R   | -   | -  | 0x00            |
| 0xFFFFFD84 | CSIE1 chip select data buffer register    | CE1CS    | -   | R/W | R/W | -  | 0xFFFF          |
| 0xFFFFFD86 | CSIE1 transmission data buffer register   | CE1TX0   | -   | -   | R/W | -  | 0x0000          |
| 0xFFFFFD86 | CSIE1 transmission data buffer register L | CE1TXL0  | -   | R/W | -   | -  | 0x00            |
| 0xFFFFFD87 | CSIE1 transmission data buffer register H | CE1TXH0  | -   | R/W | -   | -  | 0x00            |
| 0xFFFFFD88 | Queued CSI1 status register               | CE1STR   | R/W | R/W | -   | -  | 0x20            |
| 0xFFFFFD89 | Queued CSI1 control register 2            | CE1CTL2  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFD8C | Queued CSI1 control register 3            | CE1CTL3  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFD8D | Queued CSI1 control register 4            | CE1CTL4  | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFD90 | Queued CSI1 enhanced timing register 0    | CE1OPT0  | -   | -   | R/W | -  | 0x0002          |
| 0xFFFFFD92 | Queued CSI1 enhanced timing register 1    | CE10PT1  | -   | -   | R/W | -  | 0x0002          |
| 0xFFFFFD94 | Queued CSI1 enhanced timing register 2    | CE1OPT2  | -   | -   | R/W | -  | 0x0002          |
| 0xFFFFFD96 | Queued CSI1 enhanced timing register 3    | CE1OPT3  | -   | -   | R/W | -  | 0x0002          |
| 0xFFFFFDC0 | Prescaler mode register 0                 | PRSM0    | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFDC1 | Prescaler compare registers 0             | PRSCM0   | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFDD0 | Prescaler mode register 1                 | PRSM1    | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFDD1 | Prescaler compare registers 1             | PRSCM1   | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFDE0 | Prescaler mode register 2                 | PRSM2    | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFDE1 | Prescaler compare registers 2             | PRSCM2   | R/W | R/W | -   | -  | 0x00            |
| 0xFFFFFE00 | DMA wait control register 0               | DMAWC0   | -   | R/W | -   | -  | 0x37            |
| 0xFFFFFE02 | DMA wait control register 1               | DMAWC1   | -   | R/W | -   | -  | 0x07            |



## **Revision History**

The following revision list shows all functional changes compared to the previous manual version R01UH0120ED0200 (published on September 24, 2010).

| 4       103       unused interrupt INTTSOCC1B removed         4       103       unused interrupt INTTSOCC2B removed         4       103       unused interrupt INTTSOCC2B removed         4       103       unused interrupt INTTSICC2B removed         4       103       unused interrupt INTTSICC3B removed         4       103       unused interrupt INTTSICC2B removed         4       103       unused interrupt INTTSOCC3B, INTTSOCC2B, INTSOCC2B, INTSOCC2B, INTSOCC2B, INTSOCC3B, INTSOCC3B, INTSOCC3B, INTSOCC3B, INTSOCC3B, INTSOCC3B, INTSOCC3B, INTTSOCC3B, INTSOCC3B, INT                                                                                                                                                                                                                                                                         | Chapter | Page | Description                                                    |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------|----------------------------------------------------------------|
| 4       103       unused interrupt INTTS0CC3B removed         4       103       unused interrupt INTTS1CC1B removed         4       103       unused interrupt INTTS1CC2B removed         4       103       unused interrupt INTTS1CC3B removed         4       103       unused interrupt INTTS1CC3B removed         4       120       interrupt control registers (C2ERRIC, C2EUPIC, C2ERRIC, C3WUPIC, C3WIPIC, C3WIPIC                                                                                                                                                                                                                             | 4       | 103  | unused interrupt INTTS0CC1B removed                            |
| 4       103       unused interrupt INTTS1CC1B removed         4       103       unused interrupt INTTS1CC2B removed         4       103       unused interrupt INTTS1CC2B removed         4       103       unused interrupt INTTS1CC3B removed         4       103       unused interrupt INTTS1CC3B removed         4       120       Interrupt control registers (C2ERRIC, C2WUPIC, C2ERRIC, C3ERRIC, C3WUPIC, C2ERRIC, TSUC3B, INTTS1CC1B, INTTS0CC3B, INTTS1CC3B, INTTS1CC4D, and INTS1CC3B         7       185       caution for boot block cluster protection added         11       247       bit name of transfer statuts flag corrected         12       280       access direction of CBnTX0 register corrected to read/write         12       290       this         12       291       this         12       293       this         12       294       this         12       294       CSIBn transmit data register corrected to CBnTX0         12       294       CSIBn transmit data register corrected in figure to CBnTX0         12       301       CSIBn transmit ada register corrected to figure to CBnTX0         12       302       CSIBn transmit ada register corrected in figure to CBnTX0 <td>4</td> <td>103</td> <td>unused interrupt INTTS0CC2B removed</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 4       | 103  | unused interrupt INTTS0CC2B removed                            |
| 4       103       unused interrupt INTTS1CC2B removed         4       103       unused interrupt INTTS1CC3B removed         4       120       interrupt control registers (C2ERRIC, C2WUPIC, C2ERRIC, C3ERRIC, C3WUPIC, C2ERRIC, C3B, INTTS0CC3B, INTTS1CC1B, INTTS1CC2B, and INTTS1CC3B         7       185       caution for boot block cluster protection added         11       247       bit name of SBF transmission trigger bit corrected         11       247       bit name of CBnTX0L register corrected to read/write         12       288       misleading reference replaced by dedicated configuration of CBnCKP and CBnDAP         12       290       bits         12       291       its         12       293       its         12       294       bits         12       295       cSiBn transmit data register corrected to CBnTX0         12       301       CSiBn transmit data register corrected in figure to CBnTX0         12       302       CSiBn transmit and receive data register, respectively, corrected in figure to CBnTX0 and CBnRX0         12       304       CSiBn transmit and receive data register, respectively, corrected in figure to CBnTX0 and CBnRX0         12       306       CSiBn transmit and re                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 4       | 103  | unused interrupt INTTS0CC3B removed                            |
| 4       103       unused interrupt INTTS1CC3B removed         4       120       interrupt control registers (C2ERRIC, C2WUPIC, C2ERRIC, C3ERRIC, C3WUPIC, C2ERRIC) removed for unused interrupts INTTS0CC1B, INTTS0CC2B, INTTS0CC2B, INTTS0CC2B, INTTS0CC3B, INTS0CC3B, INTS0CC3B, INTS0CC3B, INTS0C3C, INTS0CC3B, INTS0C, INTS0C, INTS0C, INTS0C, I                                             | 4       | 103  | unused interrupt INTTS1CC1B removed                            |
| 4       120       interrupt control registers (C2ERRIC, C2WUPIC, C2ERRIC, C3ERRIC, C3WUPIC, C2ERRIC), removed for unused interrupts INTTSOCC1B, INTTSOCC2B, INTTSOCC3B, INTSOCAB, I | 4       | 103  | unused interrupt INTTS1CC2B removed                            |
| C2EFIRIC) removed for unused interrupts INTTSOCC18, INTTSOCC28,<br>INTTSOCC38, INTTS1CC18, INTTS1CC28, and INTTS1CC38           7         185         caution for boot block cluster protection added           11         247         bit name of SBF transmission trigger bit corrected           11         247         bit name of transfer statuts flag corrected           12         280         access direction of CBnTX0L register corrected to read/write           12         281         misleading reference replaced by dedicated configuration of CBnCKP and CBnDAP           12         293         bits           12         294         bits           12         293         bits           12         294         bits           12         295         bits           12         295         bits           12         294         bits           12         295         bits           12         296         CSIBn transmit data register corrected to CBnTX0           12         301         CSIBn transmit data register corrected in figure to CBnTX0           12         302         CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX0           12         304         CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 4       | 103  | unused interrupt INTTS1CC3B removed                            |
| 11       247       bit name of SBF transmission trigger bit corrected         11       247       bit name of transfer statuts flag corrected         12       280       access direction of CBnTX0L register corrected to read/write         12       280       misleading reference replaced by dedicated configuration of CBnCKP and CBnDAP bits         12       291       bits         12       293       pits         12       294       pits         12       294       pits         12       295       pits         12       294       pits         12       295       pits         12       296       CSIBn transmit data register corrected to CBnTX0         12       301       CSIBn transmit data register corrected in figure to CBnTX0         12       302       CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX0         12       303       CSIBn transmit data register corrected in figure to CBnTX0         12       304       CSIBn transmit data register corrected in figure to CBnTX0         12       305       CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX0 and CBnRX0         13       326       caution of write to CEnCS register corrected         13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 4       | 120  | C2ERRIC) removed for unused interrupts INTTS0CC1B, INTTS0CC2B, |
| 11       247       bit name of transfer statuts flag corrected         12       280       access direction of CBnTX0L register corrected to read/write         12       288       misleading reference replaced by dedicated configuration of CBnCKP and CBnDAP         12       290       bits         12       291         12       293         12       294         12       295         12       295         12       296         12       297         12       296         12       297         12       296         12       301         CSIBn transmit data register corrected to CBnTX0         12       302         CSIBn transmit data register corrected in figure to CBnTX0         12       303         CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX0         12       304       CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX0         12       304       CSIBn transmit and receive data register corrected         13       326       caution of write to CEnCS register corrected         13       326       caution of write to CEnCN register corrected         13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 7       | 185  | caution for boot block cluster protection added                |
| 12       280       access direction of CBnTX0L register corrected to read/write         12       288       misleading reference replaced by dedicated configuration of CBnCKP and CBnDAP         12       290       bits         12       291         12       293         12       294         12       295         12       295         12       296         12       297         12       296         12       301         CSIBn transmit data register corrected to CBnTX0         12       302         CSIBn receive data register corrected in figure to CBnRX0         12       303         CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX0 and CBnRX0         12       304         CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX0 and CBnRX0         12       306       CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX0         13       326       caution of write to CEnCS register corrected         13       329       caution of write to CEnCPTm register corrected         13       329       caution of write to CEnTX0 register corrected         14       370       term                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 11      | 247  | bit name of SBF transmission trigger bit corrected             |
| 12       288       misleading reference replaced by dedicated configuration of CBnCKP and CBnDAP bits         12       291         12       291         12       293         12       294         12       295         12       295         12       297         12       296         12       297         12       296         12       297         12       296         12       297         12       296         12       301         CSIBn transmit data register corrected to CBnTX0         12       302         CSIBn receive data register corrected in figure to CBnTX0         12       303         CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX0 and CBnRX0         12       304       CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX0 and CBnRX0         12       306       CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX0         13       326       caution of write to CEnTX0 register corrected         13       329       caution of write to CEnTX0 register corrected         14       370       term "m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 11      | 247  | bit name of transfer statuts flag corrected                    |
| 122901229112293122941229512296122961229612296123011230212303123031230312304123051230512305123061230613326133291437015370165851658616586                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 12      | 280  | access direction of CBnTX0L register corrected to read/write   |
| 12290122911229312294122951229612297122961230112302123021230312303123031230412305123051230612306123061332613326133291437015370165851658616586                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 12      | 288  |                                                                |
| 1229312294122951229712296122961230112301123021230212303123031230412304123051230612306123061332613329133221437015563165861658616586                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 12      | 290  | bits                                                           |
| 12294122951229712296CSIBn transmit data register corrected to CBnTX012301CSIBn transmit data register corrected in figure to CBnTX012302CSIBn receive data register corrected in figure to CBnRX012303CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX012304CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX012304CSIBn transmit data register corrected in figure to CBnTX012305CSIBn transmit data register corrected in figure to CBnTX012306CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX012306CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX013326caution of write to CEnCS register corrected13329caution of write to CEnTX0 register corrected14370term "memory access controller" replaced by "message control module" according to block diagram of CAN module16585formula of PWM duty factor corrected16586formula of PWM duty factor corrected16586formula of PWM cycle corrected16586formula of PWM cycle corrected16586formula of PWM cycle corrected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 12      | 291  |                                                                |
| 122951229712296CSIBn transmit data register corrected to CBnTX012301CSIBn transmit data register corrected in figure to CBnTX012302CSIBn receive data register corrected in figure to CBnRX012303CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX012304CSIBn transmit data register corrected in figure to CBnTX012304CSIBn transmit data register corrected in figure to CBnTX012305CSIBn transmit data register corrected in figure to CBnTX012306CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX012306CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX013326caution of write to CEnCS register corrected13329caution of write to CEnCN register corrected14370term "memory access controller" replaced by "message control module" according to block diagram of CAN module16563incorrect item OVFW in figure corrected16586formula of PWM duty factor corrected16586formula of PWM cycle corrected16586formula of PWM cycle corrected16586formula of PWM cycle corrected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 12      | 293  |                                                                |
| 1229712296CSIBn transmit data register corrected to CBnTX012301CSIBn transmit data register corrected in figure to CBnTX012302CSIBn receive data register corrected in figure to CBnRX012303CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX012304CSIBn transmit data register corrected in figure to CBnTX012304CSIBn transmit data register corrected in figure to CBnTX012305CSIBn transmit data register corrected in figure to CBnTX012306CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX012306CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX013326caution of write to CEnCS register corrected13329caution of write to CEnTX0 register corrected14370term "memory access controller" replaced by "message control module" according to block diagram of CAN module16563incorrect item OVFW in figure corrected16586formula of PWM duty factor corrected16586formula of PWM cycle corrected16586formula of PWM cycle corrected16586formula of PWM cycle corrected16586formula of PWM cycle corrected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 12      | 294  |                                                                |
| 12296CSIBn transmit data register corrected to CBnTX012301CSIBn transmit data register corrected in figure to CBnTX012302CSIBn receive data register corrected in figure to CBnRX012303CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX012304CSIBn transmit data register corrected in figure to CBnTX012304CSIBn transmit data register corrected in figure to CBnTX012305CSIBn transmit data register corrected in figure to CBnTX012306CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX012306CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX012306CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX013326caution of write to CEnCS register corrected13329caution of write to CEnTX0 register corrected14370term "memory access controller" replaced by "message control module" according to block diagram of CAN module16585formula of PWM duty factor corrected16586formula of PWM cycle corrected16586formula of PWM cycle corrected16586formula of PWM cycle corrected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 12      | 295  |                                                                |
| 12301CSIBn transmit data register corrected in figure to CBnTX012302CSIBn receive data register corrected in figure to CBnRX012303CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX0<br>and CBnRX012304CSIBn transmit data register corrected in figure to CBnTX012305CSIBn transmit data register corrected in figure to CBnTX012306CSIBn transmit data register corrected in figure to CBnRX012306CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX0<br>and CBnRX013326caution of write to CEnCS register corrected13329caution of write to CEnTX0 register corrected13332access direction for CEnOPTm register corrected14370term "memory access controller" replaced by "message control module" according to<br>block diagram of CAN module16585formula of PWM duty factor corrected16586formula of PWM cycle corrected16586formula of PWM cycle corrected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 12      | 297  |                                                                |
| 12302CSIBn receive data register corrected in figure to CBnRX012303CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX0<br>and CBnRX012304CSIBn transmit data register corrected in figure to CBnTX012305CSIBn transmit data register corrected in figure to CBnRX012306CSIBn receive data register corrected in figure to CBnRX012306CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX0<br>and CBnRX013326caution of write to CEnCS register corrected13329caution of write to CEnTX0 register corrected13322access direction for CEnOPTm register corrected14370term "memory access controller" replaced by "message control module" according to<br>block diagram of CAN module16563incorrect item OVFW in figure corrected16585formula of PWM duty factor corrected16586formula of PWM cycle corrected16586formula of PWM cycle corrected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 12      | 296  | CSIBn transmit data register corrected to CBnTX0               |
| 12303CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX0<br>and CBnRX012304CSIBn transmit data register corrected in figure to CBnTX012305CSIBn receive data register corrected in figure to CBnRX012306CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX0<br>and CBnRX013326caution of write to CEnCS register corrected13329caution of write to CEnTX0 register corrected13332access direction for CEnOPTm register corrected14370term "memory access controller" replaced by "message control module" according to<br>block diagram of CAN module16563formula of PWM duty factor corrected16585formula of PWM cycle corrected16586formula of PWM cycle corrected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 12      | 301  | CSIBn transmit data register corrected in figure to CBnTX0     |
| and CBnRX012304CSIBn transmit data register corrected in figure to CBnTX012305CSIBn receive data register corrected in figure to CBnRX012306CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX0<br>and CBnRX013326caution of write to CEnCS register corrected13329caution of write to CEnTX0 register corrected13332access direction for CEnOPTm register corrected14370term "memory access controller" replaced by "message control module" according to<br>block diagram of CAN module16563incorrect item OVFW in figure corrected16586formula of PWM duty factor corrected16585formula of PWM cycle corrected16586formula of PWM cycle corrected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 12      | 302  | CSIBn receive data register corrected in figure to CBnRX0      |
| 12305CSIBn receive data register corrected in figure to CBnRX012306CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX0<br>and CBnRX013326caution of write to CEnCS register corrected13329caution of write to CEnTX0 register corrected13332access direction for CEnOPTm register corrected14370term "memory access controller" replaced by "message control module" according to<br>block diagram of CAN module16563incorrect item OVFW in figure corrected16585formula of PWM duty factor corrected16586formula of PWM cycle corrected16586formula of PWM cycle corrected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 12      | 303  |                                                                |
| 12306CSIBn transmit and receive data register, respectively, corrected in figure to CBnTX0<br>and CBnRX013326caution of write to CEnCS register corrected13329caution of write to CEnTX0 register corrected13332access direction for CEnOPTm register corrected14370term "memory access controller" replaced by "message control module" according to<br>block diagram of CAN module16563incorrect item OVFW in figure corrected16585formula of PWM duty factor corrected16585formula of PWM cycle corrected16586formula of PWM cycle corrected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 12      | 304  | CSIBn transmit data register corrected in figure to CBnTX0     |
| and CBnRX013326caution of write to CEnCS register corrected13329caution of write to CEnTX0 register corrected13332access direction for CEnOPTm register corrected14370term "memory access controller" replaced by "message control module" according to<br>block diagram of CAN module16563incorrect item OVFW in figure corrected16585formula of PWM duty factor corrected16585formula of PWM cycle corrected16586formula of PWM cycle corrected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 12      | 305  | CSIBn receive data register corrected in figure to CBnRX0      |
| 13329caution of write to CEnTX0 register corrected13332access direction for CEnOPTm register corrected14370term "memory access controller" replaced by "message control module" according to<br>block diagram of CAN module16563incorrect item OVFW in figure corrected to OVFV16585formula of PWM duty factor corrected16586formula of PWM cycle corrected16585formula of PWM cycle corrected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 12      | 306  |                                                                |
| 13332access direction for CEnOPTm register corrected14370term "memory access controller" replaced by "message control module" according to<br>block diagram of CAN module16563incorrect item OVFW in figure corrected to OVFV16585formula of PWM duty factor corrected16586formula of PWM cycle corrected16586formula of PWM cycle corrected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 13      | 326  | caution of write to CEnCS register corrected                   |
| 14370term "memory access controller" replaced by "message control module" according to<br>block diagram of CAN module16563incorrect item OVFW in figure corrected to OVFV16585formula of PWM duty factor corrected16586formula of PWM cycle corrected16585formula of PWM cycle corrected16586formula of PWM cycle corrected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 13      | 329  | caution of write to CEnTX0 register corrected                  |
| block diagram of CAN module16563incorrect item OVFW in figure corrected to OVFV16585formula of PWM duty factor corrected16586formula of PWM cycle corrected16585formula of PWM cycle corrected16586formula of PWM cycle corrected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 13      | 332  | access direction for CEnOPTm register corrected                |
| 16585formula of PWM duty factor corrected165861658516586                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 14      | 370  |                                                                |
| 16         586           16         585           16         585           16         586                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 16      | 563  | incorrect item OVFW in figure corrected to OVFV                |
| 16     585     formula of PWM cycle corrected       16     586                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 16      | 585  | formula of PWM duty factor corrected                           |
| 16 586                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 16      | 586  | 1                                                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 16      | 585  | formula of PWM cycle corrected                                 |
| 17 619 description of TSnCCR1B changed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 16      | 586  | 1                                                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 17      | 619  | description of TSnCCR1B changed                                |



| Chapter | Page | Description                                                                  |  |
|---------|------|------------------------------------------------------------------------------|--|
| 17      | 620  | description of TSnCCR2B changed                                              |  |
| 17      | 621  | description of TSnCCR3B changed                                              |  |
| 17      | 647  | name of bit 8 of TSnOPT3 register changed to TSnACC2                         |  |
| 17      | 648  |                                                                              |  |
| 17      | 802  | marking in figure corrected from "TSnCCR0 to TSnDTC1" to "TSnCCR0 - TSnDTC1" |  |
| A       | 1065 | reset value and access size of CE0CS register corrected                      |  |
| A       | 1066 | reset value and access size of CE1CS register corrected                      |  |

The following revision list shows all functional changes compared to the previous manual version R01UH0120ED0210 (published on November 13, 2012)

| Chapter | Page | Description                                                                                                   |  |  |
|---------|------|---------------------------------------------------------------------------------------------------------------|--|--|
| 5       | 143  | CPU-CRC removed in figure title                                                                               |  |  |
| 7       | 170  | PG-FP4 replaced by PG-FP5 programmer in all following figures of this chapter                                 |  |  |
| 7       | 173  | PG-FP4 replaced by PG-FP5 throughout this chapter                                                             |  |  |
| 7       | 186  | URL updated                                                                                                   |  |  |
| 9       | 193  | unintended block diagram of Bus and Memory Control with Flexray controller and external bus interface removed |  |  |
| 18      | 948  | several bit identifiers corrected to TTn                                                                      |  |  |
| 18      | 962  | table "Counter Clear Option" moved to correct location                                                        |  |  |
| 18      | 971  | notation in figure corrected                                                                                  |  |  |
| 18      | 984  | high level setting replaced by active level setting throughout the subchapter                                 |  |  |
| 18      | 984  | low level setting replaced by inactive level setting throughout the subchapter                                |  |  |
| 18      | 984  | subtitel of figure corrected ( not rewritten)                                                                 |  |  |
| 18      | 988  | indication of operation flow in free-running mode corrected                                                   |  |  |
| 18      | 1018 | mixed up compare and capture interrupt notation in figure corrected                                           |  |  |



## Index

## A

A/D conversion result register for DMA (ADDMAn) 518 A/D conversion result registers (ADCRnm, ADCRnmH) 515 A/D Converter Operation in A/D trigger mode 525 Operation in external trigger mode 534 Operation in timer trigger mode 529 A/D Converter mode register 0 (ADMn0) 510 A/D Converter mode register 1 (ADMn1) 511 A/D Converter mode register 2 (ADMn2) 513 A/D Converter trigger source select register (ADTRSELn) 514 AA5OVIC 102 Access to External devices (initialization) 202 ADCRnm 515 ADCRnmH 515 ADDMAn 518 Address setup wait control register (AWC) 207 Address space 85 **CPU 85** Images 85 Physical 85 ADIC0 104, 120 ADIC1 104, 120 ADMn0 510 ADMn1 511 ADMn2 513 ADTRSELn 514 AFO (Auxiliary Frequency Output) 1042 Analog filtered inputs 63 Anytime write TMT 966 Asynchronous Serial Interface see UARTC Auxiliary Frequency Output 1042 AWC 207

## В

Batch rewrite TMT 968 Baud rate generator CSIB 307 UARTC 270 BCC 209 BCTn 206 BCU Registers 204 BCU (Bus Control Unit) 192 Boundary operation conditions 201 BPC 204 BRGIC 103, 119 BRGIC2 103, 119 BSC 206 Bus and memory control 192 Registers 203 Bus clock dividing frequency control register (DVC) 210 Bus cycle configuration register (BCTn) 206 Bus cycle control register (BCC) 209 Bus size configuration register (BSC) 206

## С

C0ERRIC 103, 119 CORECIC 103, 120 C0TRXIC 103. 120 C0WUPIC 103, 120 C1ERRIC 103, 120 C1RECIC 103, 120 C1TRXIC 103. 120 C1WUPIC 103, 120 CALLT base pointer (CTBP) 81 CAN (Controller area network) 368 CAN clock selection register (CANCKSEL) 151 CAN Controller 368 Baud rate settings 469 Bit set/clear function 400 Configuration 370 Connection with target system 392 Control registers 402 **Diagnosis functions** 464 Functions 381 Initialization 438 Internal registers 393 Interrupt function 463 Message reception 442 Message transmission 450 **Operation 477** Overview of functions 369 Power saving modes 458 Register access type 395 Register bit configuration 397 Special operational modes 464 Time stamp function 468 Transition from initialization mode to operation mode 440 CAN protocol 371 CANCKSEL 151



CANn global automatic block transmission control register (CnGMABT) 405 CANn global automatic block transmission delay register (CnGMABTD) 407 CANn global clock selection register (CnGMCS) 404 CANn global control register (CnGMCTRL) 402 CANn message configuration register m (CnMCONFm) 432 CANn message control register m (CnMCTRLm) 435 CANn message data byte register (CnMDATAxm) 429 CANn message data length register m (CnMDLCm) 431 CANn message ID register m (CnMIDLm, CnMIDHm) 434 CANn module bit rate prescaler register (CnBRP) 420 CANn module bit rate register (CnBTR) 421 CANn module control register (CnCTRL) 410 CANn module error counter register (CnERC) 416 CANn module information register (CnINFO) 415 CANn module interrupt enable register (CnIE) 417 CANn module interrupt status register (CnINTS) 419 CANn module last error information register (CnLEC) 413 CANn module last in-pointer register (CnLIPT) 422 CANn module last out-pointer register (CnLOPT) 424 CANn module mask control register (Cn-MASKaL, CnMASKaH) 408 CANn module receive history list register (CnRGPT) 423 CANn module time stamp register (CnTS) 427 CANn module transmit history list register (CnTGPT) 425 CB0REIC 103, 120 CB0RIC 103, 120 CB0TIC 103, 120 CB1REIC 104, 120 CB1RIC 104, 120 CB1TIC 104, 120 CBnCTL0 281 CBnCTL1 283 CBnCTL2 285 CBnRX0 280 CBnRX0L 280

CBnSTR 287 CBnTX 145, 280 CBnTX0 280 CBnTX0L 280 CBnTXL 280 CCRCINn (CPU-CRC input register) 145 CE0CIC 104, 120 CE00FIC 104, 120 CE1CIC 104, 120 CE10FIC 104, 120 CEnCS 326 CEnCTL0 316 CEnCTL1 318 CEnCTL2 321 CEnCTL3 322 CEnCTL4 323 CEnOPTm 332 CEnRX0 325 CEnSTR 330 CEnTX0 329 Chip area select control register (CSCn) 206 Chip select data buffer registers (CEnCS) 326 Chip select signals 194 Clock Generator 148 Clock Monitor 152 **Clocked Serial Interface** see CSIB CnBRP 420 CnBTR 421 CnCTRL 410 CnERC 416 CnGMABT 405 CnGMABTD 407 CnGMCS 404 CnGMCTRL 402 CnIE 417 CnINFO 415 CnINTS 419 CnLEC 413 CnLIPT 422 CnLOPT 424 CnMASKaH 408 CnMASKaL 408 CnMCONFm 432 CnMCTRLm 435 CnMDATAxm 429 CnMDLCm 431 CnMIDHm 434 CnMIDLm 434 CnRGPT 423

CnTGPT 425 CnTS 427 Command register (PRCMD) 38 CPU Address space 85 Functions 71 Register set 73 CPU-CRC 142 CRC base address 200 CCRCINn (CPU-CRC input register) 145 CPU-CRC 142 CRCC (CRC control register) 146 DATA-CRC 142 DCRCIN 145 Registers 144 CRC (Cyclic Redundancy Check) 142 CRCC (CRC control register) 146 CSCn 206 CSIB Baud rate generator 307 Control registers 281 **Operation 288** Operation flow 301 Output pins 300 CSIB (Clocked Serial Interface) 278 CSIB transmit data register (CBnTX) 145 CSIBn control register 0 (CBnCTL0) 281 CSIBn control register 1 (CBnCTL1) 283 CSIBn control register 2 (CBnCTL2) 285 CSIBn receive data register (CBnRX0) 280 CSIBn status register (CBnSTR) 287 CSIBn transmit data register (CBnTX) 280 CSIBn transmit data register (CBnTX0) 280 CTBP 81 CTPC 76 CTPSW 79 Cyclic Redundancy Check (CRC) 142

## D

Data address space Recommended use 96 Data flash 199 base address 199 Data flash control register (DFLCTL) 169 Data space 87 Data wait control register (DWCn) 208 DATA-CRC 142 DBPC 76 DBPSW 79

DCRCIN 145 Debug function (on-chip) 1034 Code protection 187 Restrictions and Cautions 1041 Debug trap 136 DFLCTL 169 Digitally filtered inputs 64 DMA (direct memory access) 211 DMA Controller 211 DMA data size control register (DMDSCL) 222 DMA mode control register (DMAMCL) 221 DMA status register (DMASL) 220 DMA transfer Forcible termination 212 Serial data reception 232 Serial data transmission 236 Timer AA capture register 240 DMA transfer count registers (DTCRn) 219 DMA transfer memory start address registers (MARn) 217 DMA transfer SFR start address registers (SARm) 216 DMA trigger factor registers (DTFRn) 218 DMA wait control registers (DMAWCm) 215 DMAIC2 104, 120 DMAIC3 104, 120 DMAMCL 221 DMASL 220 DMAWCm 215 DMDSCL 222 DTCRn 219 DTFRn 218 DVC 210 DWCn 208 Ε

ECR 80 **ECT 83 EFG 82** EIPC 76 EIPSW 79 Element pointer 74 Emergency shut off control register (PESCn) 34 Emergency shut-off mask register (PESMKn) 37 Emergency shut-off status register (ESOSTn) 36 ERRIC 100, 118 ESOSTn 36 Exception status flag (EP) 133 Exception trap 134

External bus properties 201 External devices Initialization for access 202 External interrupt edge specification register (INTM0) 124 External interrupt edge specification register (INTM1) 125 External interrupt edge specification register (INTM2) 126 External interrupt edge specification register (INTM3) 126 External memory area 90

## F

FEPC 76 FEPSW 79 Fixed peripheral I/O area 197 Flash area 89 Flash memory 159 Self-programming 181 Flash programmer Communication mode 171 Pin connection 173 Flash programming Mode 84 Flash ROM ECC error register (ROMEAD) 166 Floating point arithmetic control register (ECT) 83 Floating point arithmetic flag register (EFG) 82 Floating point arithmetic register set 82

## G

General purpose registers (r0 to r31) 74 Global pointer 74

## Η

HALT mode 156, 157 release 157

## I

ID code 1036 Idle pins Recommended connection 68 Images in address space 85 IMRn 120 inital value of Pn registers changed to "undefined" 32 Initialization for access to external devices 202 In-service priority register (ISPR) 122 INTC (Interrupt Controller) 99 Internal flash area 89 Internal peripheral function wait control register

(VSWC) 205 Internal RAM area 89 **INTERRF 130** Interrupt Maskable 110 Non-maskable 105 Processing (multiple interrupts) 138 Response time 140 Interrupt Controller 99 Debug trap 136 Edge and level detection configuration 124 Exception trap 134 Periods in which interrupts are not acknowledged 141 Software exception 131 Interrupt mask registers IMRn 120 Interrupt share enable register (INTSEL) 129 Interrupt source flag register (INTERRF) 130 Interrupt/exception source register (ECR) 80 INTM0 124 INTM1 125 INTM2 126 **INTM3 126 INTSEL 129 ISPR 122** 

## L

Link pointer 74

## Μ

MARn 217 Maskable interrupt status flag (ID) 123 Maskable interrupts 110 Maskable Interrupts Control Register (xxICn) 117 MEMC (Memory Controller) 192 Memory 89 Access configuration 210 Areas 89 Blocks 194 Controller registers 206 MODE pins 84

## Ν

Noise elimination Pin input 63 Noise rejection time control register (NRC) 66 Non-maskable interrupts 105 Normal operation mode 84 NRC 66 N-Wire Code protection 187 Connection to emulator 1037 Emulator 1034 ID code 1036 Security function 1036

## 0

on-chip debug cautions revised 1041 Operation modes 84 Flash programming mode 84 Normal operation mode 84 OSDIC 100, 118

## Ρ

Package pins assignment 69 PC 76 PC saving registers 76 Peripheral area selection control register (BPC) 204 Peripheral I/O area fixed 197 programmable 90, 197 Peripheral status register (PHS) 39 PESCn 34 PESMKn 37 PFCEn 31 PFCn 31 PHS 39 Physical address space 85 PIC0 100, 118 PIC1 100, 118 PIC10 100, 118 PIC11 100, 118 PIC12 100, 118 PIC2 100, 118 PIC3 100, 118 PIC4 100, 118 PIC5 100, 118 PIC6 100, 118 PIC7 100, 118 PIC8 100, 118 PIC9 100, 118 Pin functions 23 After reset/in stand-by modes 67 List 45 Unused pins 68 PMCn 29 PMn 30 Pn 32 Port function control expansion register (PFCEn) 31

Port function control register (PFCn) 31 Port groups 24 Configuration 40 Configuration registers 27 List 40 Port mode control register (PMCn) 29 Port mode register (PMn) 30 Port register (Pn) 32 power save function 156 PPA (programmable peripheral I/O area) 197 PRCMD 38 Prescaler compare registers (PRSCMn) 309 Prescaler compare registers 2 (PRSCM2) 1044 Prescaler mode register 2 (PRSM2) 1043 Prescaler mode registers (PRSMn) 308 Program counter (PC) 76 Program space 87 Program status word (PSW) 77 Programmable peripheral I/O area 90, 197 **PRSCM2 1044** PRSCMn 309 PRSM2 1043 PRSMn 308 **PSW 77** PSW saving registers 79

## Q

Queued CSI control register 0 (CEnCTL0) 316 Queued CSI control register 1 (CEnCTL1) 318 Queued CSI control register 2 (CEnCTL2) 321 Queued CSI control register 3 (CEnCTL3) 322 Queued CSI control register 4 (CEnCTL4) 323 Queued CSI enhanced timing registers (CEnOPTm) 332 Queued-CSI status registers (CEnSTR) 330

## R

RAM area 89 RAM ECC control register (RAMECC) 94 RAM ECC error address register (RAMEAD) 92 RAM ECC error data location register (RAMEDLR) 93 RAMEAD 92 RAMECC 94 RAMEDLR 93 Receive data buffer registers (CEnRX0) 325 regID (system register number) 75 Reload TMT 968 Reset Register status after reset 1047 ROM TAA5OVIC 119 see Internal flash area TAA6CCIC0 102, 119 ROMEAD 166 TAA6CCIC1 102, 119 TAA6OVIC 102, 119 S TAA7CCIC0 103, 119 SARm 216 TAA7CCIC1 103, 119 SARn register read/write access of 1-bit units TAA7OVIC 103, 119 added 216 TAA8CCIC0 103, 119 Saturated operation instructions 78 TAA8CCIC1 103, 119 SFR (special function register) 1049 TAA8OVIC 103, 119 Software exception 131 TAA9CCIC0 103, 119 Special function registers (list) 1049 TAA9CCIC1 103, 119 Stack pointer 74 TAA9OVIC 103, 119 System register set 75 TAAIC0 549 TAAIC1 550 Т TAAIC2 551 TAA capture/compare register 0 **TAAIC3 1023** (TAAnCCR0) 546 TAAnCCR0 546 TAA capture/compare register 1 (TAAnCCR1) 547 TAAnCCR1 547 TAA control register 0 (TAAnCTL0) 552 TAAnCNT 548 TAA counter read buffer register TAAnCTL0 552 (TAAnCNT) 548 TAAnCTL1 553 TAA dedicated I/O control register 0 TAAnIOC0 555 (TAAnIOC0) 555 TAAnIOC1 556 TAA dedicated I/O control register 1 TAAnIOC2 557 (TAAnIOC1) 556 TAAnIOC3 558 TAA I/O control register 2 (TAAnIOC2) 557 TAAnOPT0 559 TAA I/O control register 3 (TAAnIOC3) 558 TAAnOPT1 560 TAA option register 0 (TAAnOPT0) 559 TAAnSVC 561 TAA option register 1 (TAAnOPT1) 560 Text pointer 74 TAA specific overflow value control register 0 Timer I/O control register 3 (TAAIC3) 1023 (TAAnSVC) 561 Timer input control register 0 (TAAIC0) 549 TAA timer control register 1 (TAAnCTL1) 553 Timer input control register 1 (TAAIC1) 550 TAA0CCIC0 102, 119 Timer input control register 2 (TAAIC2) 551 TAA0CCIC1 102, 119 Timer S 613 TAA0OVIC 102, 119 A/D conversion trigger function 746 TAA1CCIC0 102, 119 Basic operation 689 TAA1CCIC1 102, 119 Configuration 615 TAA10VIC 102, 119 Control register 627 TAA2CCIC 119 Error/warning interrupt 752 TAA2CCIC0 102 Features 613 TAA2CCIC1 102, 119 Flags 716 TAA2OVIC 102, 119 Interrupt thinning out function 735 TAA3CCIC0 102, 119 Match interrupt 713 TAA3CCIC1 102, 119 Operation in each mode 756 TAA3OVIC 102, 119 Timer Sn compare register 0 (TSnCCR0) 618 TAA4CCIC0 102, 119 Timer Sn compare register 0A TAA4CCIC1 102, 119 (TSnCCR0A) 618 TAA4OVIC 102, 119 Timer Sn compare register 1 (TSnCCR1) 619 TAA5CCIC0 102, 119 Timer Sn compare register 1A TAA5CCIC1 102, 119

(TSnCCR1A) 619 Timer Sn compare register 1B (TSnCCR1B) 619 Timer Sn compare register 2 (TSnCCR2) 620 Timer Sn compare register 2A (TSnCCR2A) 620 Timer Sn compare register 2B (TSnCCR2B) 620 Timer Sn compare register 3 (TSnCCR3) 621 Timer Sn compare register 3A (TSnCCR3A) 621 Timer Sn compare register 3B (TSnCCR3B) 621 Timer Sn compare register 4 (TSnCCR4) 622 Timer Sn compare register 4A (TSnCCR4A) 622 Timer Sn compare register 5 (TSnCCR5) 623 Timer Sn compare register 5A (TSnCCR5A) 623 Timer Sn control register 0 (TSnCTL0) 627 Timer Sn control register 1 (TSnCTL1) 629 Timer Sn counter read register (TSnCNT) 624 Timer Sn dead time setting register 0 (TSnDTC0) 625 Timer Sn dead time setting register 0A (TSnDTC0A) 625 Timer Sn dead time setting register 1 (TSnDTC1) 626 Timer Sn dead time setting register 1A (TSnDTC1A) 626 Timer Sn I/O control register 0 (TSnIOC0) 631 Timer Sn I/O control register 2 (TSnIOC2) 633 Timer Sn I/O control register 4 (TSnIOC4) 634 Timer Sn option register (TSnOPT6) 680 Timer Sn option register 0 (TSnOPT0) 636 Timer Sn option register 4 (TSnOPT4) 651 Timer Sn option register 5 (TSnOPT5) 669 Timer Sn option register 7 (TSnOPT7) 683 Timer Sn option registers 1, 1H, 1L (TSnOPT1, TSnOPT1H, TSnOPT1L) 638 Timer Sn option registers 1A, 1AH, 1AL (TSnOPT1A, TSnOPT1AH, TSnOPT1AL) 638 Timer Sn option registers 2, 2H, 2L (TSnOPT2, TSnOPT2H, TSnOPT2L) 643 Timer Sn option registers 3, 3H, 3L (TSnOPT3, TSnOPT3H, TSnOPT3L) 647 Timer Sn pattern register 0 (TSnPAT0) 685 Timer Sn pattern register 1 (TSnPAT1) 687 Timer Sn sub-counter read register (TSnSBC) 624 TMT

Anytime write 966 Batch rewrite 968 Reload 968 TMTn capture/compare register 0 (TTnCCR0) 944 TMTn capture/compare register 1 (TTnCCR1) 945 TMTn control register 0 (TTnCTL0) 947 TMTn control register 1 (TTnCTL1) 949 TMTn control register 2 (TTnCTL2) 951 TMTn counter read buffer register (TTnCNT) 946 TMTn counter write buffer register (TTnTCW) 946 TMTn I/O control register 0 (TTnIOC0) 953 TMTn I/O control register 1 (TTnIOC1) 954 TMTn I/O control register 2 (TTnIOC2) 955 TMTn I/O control register 3 (TTnIOC3) 956 TMTn option register 0 (TTnOPT0) 958 TMTn option register 1 (TTnOPT1) 959 TMTn option register 2 (TTnOPT2) 961 Transmission data buffer registers (CEnTX0) 329 TSOCCIC 101 TSOCCICO 118 TS0CCIC1 101, 118 TS0CCIC2 101, 118 TS0CCIC3 101, 118 TS0CCIC4 101, 118 TS0CCIC5 101, 118 TS0CDIC0 101, 118 TS0ERIC 101, 118 TS00DIC 101, 118 TS00VIC 101, 118 TS0WNIC 101, 118 TS1CCIC0 101, 118 TS1CCIC1 101, 118 TS1CCIC2 101, 118 TS1CCIC3 101, 118 TS1CCIC4 101, 118 TS1CCIC5 101, 118 TS1CDIC0 101, 118 TS1ERIC 101, 118 TS10DIC 101, 118 TS10VIC 101, 118 TS1WNIC 101, 118 TSnCCR0 618 TSnCCR0A 618 TSnCCR1 619 TSnCCR1A 619

TSnCCR1B 619

TSnCCR2 620 TSnCCR2A 620 TSnCCR2B 620 TSnCCR3 621 TSnCCR3A 621 TSnCCR3B 621 TSnCCR4 622 TSnCCR4A 622 TSnCCR5 623 TSnCCR5A 623 TSnCNT 624 TSnCTL0 627 TSnCTL1 629 TSnDTC0 625 TSnDTC0A 625 TSnDTC1 626 TSnDTC1A 626 TSnIOC0 631 TSnIOC2 633 TSnIOC4 634 TSnOPT0 636 TSnOPT1, TSnOPT1H, TSnOPT1L 638 TSnOPT1A, TSnOPT1AH, TSnOPT1AL 638 TSnOPT2, TSnOPT2H, TSnOPT2L 643 TSnOPT3, TSnOPT3H, TSnOPT3L 647 TSnOPT4 651 TSnOPT5 669 TSnOPT6 680 TSnOPT7 683 TSnPAT0 685 TSnPAT1 687 TSnSBC 624 TT0CCIC0 101, 119 TT0CCIC1 101, 119 TT0ECIC 101, 119 TT00VIC 101, 118 TT1CCIC0 102, 119 TT1CCIC1 102, 119 TT1ECIC 102, 119 TT10VIC 102, 119 TTnCCR0 944 TTnCCR1 945 TTnCNT 946 TTnCTL0 947 TTnCTL1 949 TTnCTL2 951 TTnIOC0 953 TTnIOC1 954 TTnIOC2 955 TTnIOC3 956

TTnOPT0 958 TTnOPT1 959 TTnOPT2 961 TTnTCW 946

## U

UARTC Cautions 277 Dedicated baud rate generator 270 Interrupt Request Signals 255 **Operation 256** UARTCn control register 0 (UCnCTL0) 245 UARTCn control register 1 (UCnCTL1) 271 UARTCn control register 2 (UCnCTL2) 272 UARTCn option control register 0 (UCnOPT0) 247 UARTCn option control register 1 (UCnOPT1) 249 UARTCn option control register 2 (UCnOPT2) 250 UARTCn receive data register (UCnRX) 253 UARTCn receive shift register 243 UARTCn status register (UCnSTR) 251 UARTCn transmit data register (UCnTX) 254 UARTCn transmit shift register 244 UC0REIC 104, 120 UC0TIC 104, 120 UC1REIC 104, 120 UC1TIC 104, 120 UCnCTL0 245 UCnCTL1 271 UCnCTL2 272 UCnOPT0 247 UCnOPT1 249 UCnOPT2 250 UCnRX 253 UCnSTR 251 UCnTX 254

## V

VSWC 205

## W

Write protected registers 97

## Ζ

Zero register 74

#### V850E/PHC3 User Manual

| Publication Date: | Rev. 2.20                       | December 12, 2013 |
|-------------------|---------------------------------|-------------------|
| Published by:     | Renesas Electronics Corporation |                   |



#### SALES OFFICES

**Renesas Electronics Corporation** 

http://www.rene

Refer to "http://www.renesas.com/" for the latest and detailed information.

 Renesas Electronics America Inc.

 2880 Scott Boulevard Santa Clara, CA 95050-2554, U.S.A.

 Tel: +1-408-588-6000, Fax: +1-408-588-6130

 Renesas Electronics Canada Limited

 1011 Nicholson Road, Newmarket, Ontario L3Y 9C3, Canada

 Tel: +1-905-989-5441, Fax: +1-905-5898-5420

 Renesas Electronics Curpe Limited

 Bukes Meadow, Milboard Road, Bourne End, Buckinghamshire, SL8 5FH, U.K

 Tel: +4921-585-100, Fax: +44-1629-585-900

 Renesas Electronics Curpe GmbH

 Arcadastrasse 10, 40472 Düsseldorf, Germany

 Tel: +4921-165030, Fax: +49-211-65030, Fax: +49-21-65030, Fax: +49-21-65030, Fax: +49-21-6503, Fax: +49-21-6

© 2010 Renesas Electronics Corporation. All rig

V850E/PHC3

