

# XC27x5X Derivatives

16/32-Bit Single-Chip Microcontroller with  
32-Bit Performance

Volume 1 (of 2): System Units

Microcontrollers



Never stop thinking

**Edition 2008-09****Published by**

**Infineon Technologies AG  
81726 Munich, Germany**

**© 2008 Infineon Technologies AG  
All Rights Reserved.**

**Legal Disclaimer**

The information given in this document shall in no event be regarded as a guarantee of conditions or characteristics. With respect to any examples or hints given herein, any typical values stated herein and/or any information regarding the application of the device, Infineon Technologies hereby disclaims any and all warranties and liabilities of any kind, including without limitation, warranties of non-infringement of intellectual property rights of any third party.

**Information**

For further information on technology, delivery terms and conditions and prices, please contact the nearest Infineon Technologies Office ([www.infineon.com](http://www.infineon.com)).

**Warnings**

Due to technical requirements, components may contain dangerous substances. For information on the types in question, please contact the nearest Infineon Technologies Office.

Infineon Technologies components may be used in life-support devices or systems only with the express written approval of Infineon Technologies, if a failure of such components can reasonably be expected to cause the failure of that life-support device or system or to affect the safety or effectiveness of that device or system. Life support devices or systems are intended to be implanted in the human body or to support and/or maintain and sustain and/or protect human life. If they fail, it is reasonable to assume that the health of the user or other persons may be endangered.

# XC27x5X Derivatives

16/32-Bit Single-Chip Microcontroller with  
32-Bit Performance

Volume 1 (of 2): System Units

Microcontrollers



Never stop thinking

---

## XC27x5X

### Revision History: V1.2, 2008-09

---

Previous Version(s):

V1.0, 2008-06 (V1.1 skipped)

| Page | Subjects (major changes since last revision) |
|------|----------------------------------------------|
|      |                                              |
|      |                                              |
|      |                                              |
|      |                                              |

---

### We Listen to Your Comments

Any information within this document that you feel is wrong, unclear or missing at all?

Your feedback will help us to continuously improve the quality of this document.

Please send your proposal (including a reference to this document) to:

[mcdocu.comments@infineon.com](mailto:mcdocu.comments@infineon.com)



**Summary Of Chapters****Summary Of Chapters**

This User's Manual consists of two Volumes, "System Units" and "Peripheral Units". For a quick overview this table of chapters summarizes both volumes, so you immediately can find the reference to the desired section in the corresponding document ([1] or [2]).

|                                                             |       |          |
|-------------------------------------------------------------|-------|----------|
| <b>Summary Of Chapters</b>                                  | ..... | 0-1 [1]  |
| <b>Table Of Contents</b>                                    | ..... | 0-3 [1]  |
| <b>1      Introduction</b>                                  | ..... | 1-1 [1]  |
| <b>2      Architectural Overview</b>                        | ..... | 2-1 [1]  |
| <b>3      Memory Organization</b>                           | ..... | 3-1 [1]  |
| <b>4      Memory Checker Module (MCHK)</b>                  | ..... | 4-1 [1]  |
| <b>5      Central Processing Unit (CPU)</b>                 | ..... | 5-1 [1]  |
| <b>6      Memory Protection Unit (MPU)</b>                  | ..... | 6-1 [1]  |
| <b>7      Interrupt and Exception Control</b>               | ..... | 7-1 [1]  |
| <b>8      System Control Unit (SCU)</b>                     | ..... | 8-1 [1]  |
| <b>9      Parallel Ports</b>                                | ..... | 9-1 [1]  |
| <b>10     Dedicated Pins</b>                                | ..... | 10-1 [1] |
| <b>11     External Bus Controller (EBC)</b>                 | ..... | 11-1 [1] |
| <b>12     Startup Configuration and Bootstrap Loading</b>   | ..... | 12-1 [1] |
| <b>13     Debug System</b>                                  | ..... | 13-1 [1] |
| <b>14     Instruction Set Summary</b>                       | ..... | 14-1 [1] |
| <b>15     Device Specification</b>                          | ..... | 15-1 [1] |
| <b>16     The General Purpose Timer Units</b>               | ..... | 16-1 [2] |
| <b>17     Real Time Clock</b>                               | ..... | 17-1 [2] |
| <b>18     Analog to Digital Converter</b>                   | ..... | 18-1 [2] |
| <b>19     Capture/Compare Unit 2</b>                        | ..... | 19-1 [2] |
| <b>20     Capture/Compare Unit 6 (CCU6)</b>                 | ..... | 20-1 [2] |
| <b>21     Universal Serial Interface Channel</b>            | ..... | 21-1 [2] |
| <b>22     Controller Area Network (MultiCAN) Controller</b> | ..... | 22-1 [2] |

**Summary Of Chapters**

|           |                                                     |       |          |
|-----------|-----------------------------------------------------|-------|----------|
| <b>23</b> | <b>Appendix: Functional and Operational Updates</b> | ..... | 23-1 [2] |
|           | <b>Keyword Index</b>                                | ..... | 24-1 [2] |
|           | <b>Register Index</b>                               | ..... | 25-8 [2] |

**Table Of Contents****Table Of Contents**

This User's Manual consists of two Volumes, "System Units" and "Peripheral Units". For your convenience this table of contents (and also the keyword and register index) lists both volumes, so you can immediately find the reference to the desired section in the corresponding document ([1] or [2]).

|                                                                     |          |
|---------------------------------------------------------------------|----------|
| <b>Summary Of Chapters .....</b>                                    | 0-1 [1]  |
| <b>Table Of Contents .....</b>                                      | 0-3 [1]  |
| <b>1      Introduction .....</b>                                    | 1-1 [1]  |
| 1.1    Members of the 16/32-bit Microcontroller Families .....      | 1-3 [1]  |
| 1.2    Summary of Basic Features .....                              | 1-5 [1]  |
| 1.3    Abbreviations .....                                          | 1-9 [1]  |
| 1.4    Naming Conventions .....                                     | 1-10 [1] |
| <b>2      Architectural Overview .....</b>                          | 2-1 [1]  |
| 2.1    Basic CPU Concepts and Optimizations .....                   | 2-2 [1]  |
| 2.1.1    Memory Protection Unit (MPU) .....                         | 2-3 [1]  |
| 2.1.2    High Instruction Bandwidth/Fast Execution .....            | 2-4 [1]  |
| 2.1.3    Powerful Execution Units .....                             | 2-5 [1]  |
| 2.1.4    High Performance Branch-, Call-, and Loop-Processing ..... | 2-6 [1]  |
| 2.1.5    Consistent and Optimized Instruction Formats .....         | 2-7 [1]  |
| 2.1.6    Programmable Multiple Priority Interrupt System .....      | 2-8 [1]  |
| 2.1.7    Interfaces to System Resources .....                       | 2-9 [1]  |
| 2.2    On-Chip System Resources .....                               | 2-10 [1] |
| 2.3    On-Chip Peripheral Blocks .....                              | 2-15 [1] |
| 2.4    Clock Generation .....                                       | 2-33 [1] |
| 2.5    Power Management .....                                       | 2-34 [1] |
| 2.6    On-Chip Debug Support (OCDS) .....                           | 2-35 [1] |
| 2.7    Protected Bits .....                                         | 2-36 [1] |
| <b>3      Memory Organization .....</b>                             | 3-1 [1]  |
| 3.1    Address Mapping .....                                        | 3-3 [1]  |
| 3.2    Register Areas .....                                         | 3-5 [1]  |
| 3.3    Data Memory Areas .....                                      | 3-10 [1] |
| 3.4    Program Memory Areas .....                                   | 3-12 [1] |
| 3.4.1    Program/Data SRAM (PSRAM) .....                            | 3-13 [1] |
| 3.4.2    Non-Volatile Program Memory (Flash) .....                  | 3-14 [1] |
| 3.5    System Stack .....                                           | 3-15 [1] |
| 3.6    IO Areas .....                                               | 3-16 [1] |
| 3.7    External Memory Space .....                                  | 3-17 [1] |
| 3.8    Crossing Memory Boundaries .....                             | 3-17 [1] |

## Table Of Contents

|          |                                                                |                |
|----------|----------------------------------------------------------------|----------------|
| 3.9      | Embedded Flash Memory . . . . .                                | 3-19 [1]       |
| 3.9.1    | Definitions . . . . .                                          | 3-19 [1]       |
| 3.9.2    | Operating Modes . . . . .                                      | 3-21 [1]       |
| 3.9.3    | Operations . . . . .                                           | 3-23 [1]       |
| 3.9.4    | Details of Command Sequences . . . . .                         | 3-26 [1]       |
| 3.9.5    | Sequence Errors . . . . .                                      | 3-36 [1]       |
| 3.9.6    | Instructions for Executing Program and Erase Jobs Concurrently | 3-37 [1]       |
| 3.9.7    | Data Integrity . . . . .                                       | 3-40 [1]       |
| 3.9.8    | Protection Handling Details . . . . .                          | 3-44 [1]       |
| 3.9.9    | Protection Handling Examples . . . . .                         | 3-51 [1]       |
| 3.9.10   | EEPROM Emulation . . . . .                                     | 3-53 [1]       |
| 3.9.11   | Interrupt Generation . . . . .                                 | 3-55 [1]       |
| 3.9.12   | Recommendations for Optimized Flash Usage . . . . .            | 3-55 [1]       |
| 3.10     | On-Chip Program Memory Control . . . . .                       | 3-57 [1]       |
| 3.10.1   | Overview . . . . .                                             | 3-57 [1]       |
| 3.10.2   | Register Interface . . . . .                                   | 3-59 [1]       |
| 3.10.3   | Error Reporting Summary . . . . .                              | 3-74 [1]       |
| 3.11     | Data Retention Memories . . . . .                              | 3-76 [1]       |
| <b>4</b> | <b>Memory Checker Module (MCHK) . . . . .</b>                  | <b>4-1 [1]</b> |
| 4.1      | Operational Overview . . . . .                                 | 4-1 [1]        |
| 4.2      | Functional Description . . . . .                               | 4-2 [1]        |
| 4.2.1    | Principle of the LFSR . . . . .                                | 4-4 [1]        |
| 4.2.2    | Principle of the MISR . . . . .                                | 4-6 [1]        |
| 4.2.3    | Commonly used Polynomials . . . . .                            | 4-7 [1]        |
| 4.2.4    | Architecture of the Memory Checker Module . . . . .            | 4-8 [1]        |
| 4.2.5    | Preferable Usage of the Memory Checker Module . . . . .        | 4-10 [1]       |
| 4.2.6    | Calculation of Seed Values (Magic Word) . . . . .              | 4-10 [1]       |
| 4.2.7    | Example Application . . . . .                                  | 4-12 [1]       |
| 4.3      | Memory Checker Module Registers . . . . .                      | 4-14 [1]       |
| 4.3.1    | Memory Checker Input Register . . . . .                        | 4-15 [1]       |
| 4.3.2    | Memory Checker Result Registers . . . . .                      | 4-16 [1]       |
| 4.3.3    | Memory Checker Count Register . . . . .                        | 4-17 [1]       |
| 4.3.4    | Memory Checker Polynomial Registers . . . . .                  | 4-18 [1]       |
| 4.4      | General Registers . . . . .                                    | 4-20 [1]       |
| 4.4.1    | ID Register . . . . .                                          | 4-20 [1]       |
| 4.5      | Interfaces of the MCHK Module . . . . .                        | 4-20 [1]       |
| <b>5</b> | <b>Central Processing Unit (CPU) . . . . .</b>                 | <b>5-1 [1]</b> |
| 5.1      | Components of the CPU . . . . .                                | 5-4 [1]        |
| 5.2      | Instruction Fetch and Program Flow Control . . . . .           | 5-5 [1]        |
| 5.2.1    | Branch Detection and Branch Prediction Rules . . . . .         | 5-7 [1]        |
| 5.2.2    | Zero-Cycle Jumps . . . . .                                     | 5-7 [1]        |
| 5.2.3    | Atomic and Extend Instructions . . . . .                       | 5-8 [1]        |

**Table Of Contents**

|          |                                                                          |          |
|----------|--------------------------------------------------------------------------|----------|
| 5.3      | Instruction Processing Pipeline . . . . .                                | 5-9 [1]  |
| 5.3.1    | Access to the IO Area . . . . .                                          | 5-10 [1] |
| 5.3.2    | Pipeline Conflicts . . . . .                                             | 5-10 [1] |
| 5.4      | CPU Configuration Registers . . . . .                                    | 5-21 [1] |
| 5.5      | Use of General Purpose Registers . . . . .                               | 5-24 [1] |
| 5.5.1    | GPR Addressing Modes . . . . .                                           | 5-26 [1] |
| 5.5.2    | Context Switching . . . . .                                              | 5-28 [1] |
| 5.6      | Code Addressing . . . . .                                                | 5-33 [1] |
| 5.7      | Data Addressing . . . . .                                                | 5-36 [1] |
| 5.7.1    | Short Addressing Modes . . . . .                                         | 5-36 [1] |
| 5.7.2    | Long Addressing Modes . . . . .                                          | 5-38 [1] |
| 5.7.3    | Indirect Addressing Modes . . . . .                                      | 5-41 [1] |
| 5.7.4    | DSP Addressing Modes . . . . .                                           | 5-43 [1] |
| 5.7.5    | The System Stack . . . . .                                               | 5-49 [1] |
| 5.8      | Standard Data Processing . . . . .                                       | 5-53 [1] |
| 5.8.1    | 16-bit Adder/Subtractor, Barrel Shifter, and 16-bit Logic Unit . . . . . | 5-57 [1] |
| 5.8.2    | Bit Manipulation Unit . . . . .                                          | 5-58 [1] |
| 5.8.3    | Multiply and Divide Unit . . . . .                                       | 5-60 [1] |
| 5.9      | DSP Data Processing (MAC Unit) . . . . .                                 | 5-62 [1] |
| 5.9.1    | MAC Unit Control . . . . .                                               | 5-63 [1] |
| 5.9.2    | Representation of Numbers and Rounding . . . . .                         | 5-63 [1] |
| 5.9.3    | The 16-bit by 16-bit Signed/Unsigned Multiplier and Scaler . . . . .     | 5-64 [1] |
| 5.9.4    | Concatenation Unit . . . . .                                             | 5-64 [1] |
| 5.9.5    | One-bit Scaler . . . . .                                                 | 5-64 [1] |
| 5.9.6    | The 40-bit Adder/Subtractor . . . . .                                    | 5-64 [1] |
| 5.9.7    | The Data Limiter . . . . .                                               | 5-65 [1] |
| 5.9.8    | The Accumulator Shifter . . . . .                                        | 5-65 [1] |
| 5.9.9    | The 40-bit Signed Accumulator Register . . . . .                         | 5-66 [1] |
| 5.9.10   | The MAC Unit Status Word MSW . . . . .                                   | 5-68 [1] |
| 5.9.11   | The Repeat Counter MRW . . . . .                                         | 5-70 [1] |
| 5.10     | Constant Registers . . . . .                                             | 5-72 [1] |
| <b>6</b> | <b>Memory Protection Unit (MPU)</b> . . . . .                            | 6-1 [1]  |
| 6.1      | Functional Overview . . . . .                                            | 6-1 [1]  |
| 6.2      | Memory Protection Registers . . . . .                                    | 6-3 [1]  |
| 6.2.1    | Protection Range Registers . . . . .                                     | 6-3 [1]  |
| 6.2.2    | Protection Mode Registers . . . . .                                      | 6-5 [1]  |
| 6.2.3    | Protection Range Data Register . . . . .                                 | 6-8 [1]  |
| 6.2.4    | Protection Range Address Register . . . . .                              | 6-8 [1]  |
| 6.3      | Functional Description . . . . .                                         | 6-10 [1] |
| 6.3.1    | Enabling Protection . . . . .                                            | 6-10 [1] |
| 6.3.2    | Protection Levels . . . . .                                              | 6-10 [1] |
| 6.3.3    | Intersecting Memory Ranges . . . . .                                     | 6-11 [1] |

**Table Of Contents**

|          |                                                               |                |
|----------|---------------------------------------------------------------|----------------|
| 6.3.4    | Protection of the MPU registers . . . . .                     | 6-11 [1]       |
| 6.3.5    | Accessing SFRs and GPRs . . . . .                             | 6-12 [1]       |
| 6.3.6    | Interrupts and PECs Handling . . . . .                        | 6-12 [1]       |
| 6.3.7    | Special handling of RETI instruction . . . . .                | 6-13 [1]       |
| 6.3.8    | Context Switch operations . . . . .                           | 6-13 [1]       |
| 6.3.9    | Debugger Access Permissions . . . . .                         | 6-14 [1]       |
| 6.3.10   | Invalid Access Traps . . . . .                                | 6-14 [1]       |
| 6.4      | Initializing and using the MPU . . . . .                      | 6-15 [1]       |
| 6.4.1    | Installing Protection . . . . .                               | 6-15 [1]       |
| 6.4.2    | Changing Protection Level . . . . .                           | 6-16 [1]       |
| 6.4.3    | Executing privileged code from non-privileged one . . . . .   | 6-17 [1]       |
| 6.4.4    | Fast task switches . . . . .                                  | 6-17 [1]       |
| 6.4.5    | Register Bank Selection . . . . .                             | 6-17 [1]       |
| 6.4.6    | Debugger Use Cases . . . . .                                  | 6-17 [1]       |
| <b>7</b> | <b>Interrupt and Exception Control . . . . .</b>              | <b>7-1 [1]</b> |
| 7.1      | Interrupt System Structure . . . . .                          | 7-3 [1]        |
| 7.2      | Interrupt Arbitration . . . . .                               | 7-5 [1]        |
| 7.3      | Interrupt Control . . . . .                                   | 7-8 [1]        |
| 7.3.1    | Interrupt Priority Level and Group Level . . . . .            | 7-9 [1]        |
| 7.3.2    | General Interrupt Control Functions in Register PSW . . . . . | 7-10 [1]       |
| 7.3.3    | Selective Interrupt Disabling . . . . .                       | 7-11 [1]       |
| 7.3.4    | Interrupt Class Management . . . . .                          | 7-12 [1]       |
| 7.4      | Interrupt Vector Table . . . . .                              | 7-14 [1]       |
| 7.5      | Interrupt Jump Table Cache . . . . .                          | 7-16 [1]       |
| 7.6      | CPU Status Saving . . . . .                                   | 7-19 [1]       |
| 7.7      | CPU Context Switch . . . . .                                  | 7-20 [1]       |
| 7.8      | Fast Bank Switching . . . . .                                 | 7-21 [1]       |
| 7.9      | Trap Functions . . . . .                                      | 7-23 [1]       |
| 7.9.1    | Software Traps . . . . .                                      | 7-23 [1]       |
| 7.9.2    | Hardware Traps . . . . .                                      | 7-24 [1]       |
| 7.10     | Peripheral Event Controller . . . . .                         | 7-31 [1]       |
| 7.10.1   | PEC Control Registers . . . . .                               | 7-32 [1]       |
| 7.10.2   | The PEC Source and Destination Pointer . . . . .              | 7-40 [1]       |
| 7.10.3   | PEC Interrupt Processing Summary . . . . .                    | 7-42 [1]       |
| 7.10.4   | PEC Channel Assignment . . . . .                              | 7-43 [1]       |
| 7.11     | External Interrupts . . . . .                                 | 7-45 [1]       |
| 7.11.1   | External Request Unit . . . . .                               | 7-45 [1]       |
| 7.11.2   | Using Peripheral Pins . . . . .                               | 7-45 [1]       |
| 7.12     | OCDS Requests . . . . .                                       | 7-47 [1]       |
| 7.13     | Service Request Latency . . . . .                             | 7-48 [1]       |
| 7.14     | Interrupt Nodes . . . . .                                     | 7-50 [1]       |
| 7.14.1   | Physical Interrupt Nodes . . . . .                            | 7-50 [1]       |

**Table Of Contents**

|          |                                                             |                |
|----------|-------------------------------------------------------------|----------------|
| 7.14.2   | Interrupt Node Sharing . . . . .                            | 7-54 [1]       |
| 7.14.3   | Interrupt Source Select Registers . . . . .                 | 7-56 [1]       |
| 7.15     | Interrupt and PEC Configuration Registers . . . . .         | 7-58 [1]       |
| <b>8</b> | <b>System Control Unit (SCU) . . . . .</b>                  | <b>8-1 [1]</b> |
| 8.1      | Clock Generation Unit . . . . .                             | 8-2 [1]        |
| 8.1.1    | Overview . . . . .                                          | 8-2 [1]        |
| 8.1.2    | Trimmed Current Controlled Wake-Up Clock (OSC_WU) . . . . . | 8-4 [1]        |
| 8.1.3    | High Precision Oscillator Circuit (OSC_HP) . . . . .        | 8-4 [1]        |
| 8.1.4    | Phase-Locked Loop (PLL) Module . . . . .                    | 8-6 [1]        |
| 8.1.5    | Clock Control Unit . . . . .                                | 8-16 [1]       |
| 8.1.6    | External Clock Output . . . . .                             | 8-22 [1]       |
| 8.1.7    | CGU Registers . . . . .                                     | 8-25 [1]       |
| 8.2      | System Timer Function (STM) . . . . .                       | 8-46 [1]       |
| 8.2.1    | STM Registers . . . . .                                     | 8-47 [1]       |
| 8.3      | Wake-up Timer (WUT) . . . . .                               | 8-49 [1]       |
| 8.3.1    | Wake-up Timer Operation . . . . .                           | 8-49 [1]       |
| 8.3.2    | WUT Registers . . . . .                                     | 8-51 [1]       |
| 8.4      | Reset Operation . . . . .                                   | 8-54 [1]       |
| 8.4.1    | Reset Architecture . . . . .                                | 8-54 [1]       |
| 8.4.2    | General Reset Operation . . . . .                           | 8-57 [1]       |
| 8.4.3    | Debug Reset Assertion . . . . .                             | 8-59 [1]       |
| 8.4.4    | Coupling of Reset Types . . . . .                           | 8-59 [1]       |
| 8.4.5    | Reset Request Trigger Sources . . . . .                     | 8-60 [1]       |
| 8.4.6    | Module Reset Behavior . . . . .                             | 8-62 [1]       |
| 8.4.7    | Reset Controller Registers . . . . .                        | 8-64 [1]       |
| 8.5      | External Service Request (ESR) Pins . . . . .               | 8-74 [1]       |
| 8.5.1    | General Operation . . . . .                                 | 8-74 [1]       |
| 8.5.2    | ESR Control Registers . . . . .                             | 8-78 [1]       |
| 8.5.3    | ESR Data Register . . . . .                                 | 8-83 [1]       |
| 8.6      | Power Supply and Control . . . . .                          | 8-84 [1]       |
| 8.6.1    | Supply Watchdog (SWD) . . . . .                             | 8-86 [1]       |
| 8.6.2    | Monitoring the Voltage Level of a Core Domain . . . . .     | 8-93 [1]       |
| 8.6.3    | Controlling the Voltage Level of a Core Domain . . . . .    | 8-100 [1]      |
| 8.6.4    | Handling the Power System . . . . .                         | 8-109 [1]      |
| 8.7      | Global State Controller (GSC) . . . . .                     | 8-110 [1]      |
| 8.7.1    | GSC Control Flow . . . . .                                  | 8-110 [1]      |
| 8.7.2    | GSC Registers . . . . .                                     | 8-114 [1]      |
| 8.8      | Software Boot Support . . . . .                             | 8-128 [1]      |
| 8.8.1    | Start-up Registers . . . . .                                | 8-128 [1]      |
| 8.9      | External Request Unit (ERU) . . . . .                       | 8-129 [1]      |
| 8.9.1    | Introduction . . . . .                                      | 8-129 [1]      |
| 8.9.2    | ERU Input Connections . . . . .                             | 8-131 [1]      |

**Table Of Contents**

|          |                                               |                |
|----------|-----------------------------------------------|----------------|
| 8.9.3    | External Request Select Unit (ERSx) . . . . . | 8-132 [1]      |
| 8.9.4    | Event Trigger Logic (ETLx) . . . . .          | 8-133 [1]      |
| 8.9.5    | Connecting Matrix . . . . .                   | 8-135 [1]      |
| 8.9.6    | Output Gating Unit (OGUy) . . . . .           | 8-136 [1]      |
| 8.9.7    | ERU Output Connections . . . . .              | 8-139 [1]      |
| 8.9.8    | ERU Registers . . . . .                       | 8-140 [1]      |
| 8.10     | SCU Interrupt Generation . . . . .            | 8-147 [1]      |
| 8.10.1   | Interrupt Support . . . . .                   | 8-148 [1]      |
| 8.10.2   | SCU Interrupt Sources . . . . .               | 8-148 [1]      |
| 8.10.3   | Interrupt Control Registers . . . . .         | 8-149 [1]      |
| 8.11     | Temperature Compensation Unit . . . . .       | 8-169 [1]      |
| 8.11.1   | Temperature Compensation Registers . . . . .  | 8-171 [1]      |
| 8.12     | Watchdog Timer (WDT) . . . . .                | 8-173 [1]      |
| 8.12.1   | Introduction . . . . .                        | 8-173 [1]      |
| 8.12.2   | Overview . . . . .                            | 8-173 [1]      |
| 8.12.3   | Functional Description . . . . .              | 8-174 [1]      |
| 8.12.4   | WDT Kernel Registers . . . . .                | 8-178 [1]      |
| 8.13     | SCU Trap Generation . . . . .                 | 8-182 [1]      |
| 8.13.1   | Trap Support . . . . .                        | 8-182 [1]      |
| 8.13.2   | SCU Trap Sources . . . . .                    | 8-183 [1]      |
| 8.13.3   | SCU Trap Control Registers . . . . .          | 8-184 [1]      |
| 8.14     | Memory Content Protection . . . . .           | 8-196 [1]      |
| 8.14.1   | Memory Checking Control Register . . . . .    | 8-197 [1]      |
| 8.14.2   | Parity Error Handling . . . . .               | 8-198 [1]      |
| 8.14.3   | ECC Error Handling . . . . .                  | 8-207 [1]      |
| 8.15     | Register Control . . . . .                    | 8-211 [1]      |
| 8.15.1   | Register Access Control . . . . .             | 8-211 [1]      |
| 8.15.2   | Register Protection Registers . . . . .       | 8-214 [1]      |
| 8.16     | Miscellaneous System Registers . . . . .      | 8-216 [1]      |
| 8.16.1   | System Registers . . . . .                    | 8-216 [1]      |
| 8.16.2   | Identification Block . . . . .                | 8-217 [1]      |
| 8.16.3   | Marker Memory . . . . .                       | 8-221 [1]      |
| 8.17     | SCU Register Addresses . . . . .              | 8-222 [1]      |
| 8.18     | Implementation . . . . .                      | 8-228 [1]      |
| 8.18.1   | Clock Generation Unit . . . . .               | 8-228 [1]      |
| 8.18.2   | External Service Requests (ESR) . . . . .     | 8-229 [1]      |
| 8.18.3   | External Request Unit (ERU) . . . . .         | 8-230 [1]      |
| <b>9</b> | <b>Parallel Ports . . . . .</b>               | <b>9-1 [1]</b> |
| 9.1      | General Description . . . . .                 | 9-2 [1]        |
| 9.1.1    | Basic Port Operation . . . . .                | 9-2 [1]        |
| 9.1.2    | Input Stage Control . . . . .                 | 9-5 [1]        |
| 9.1.3    | Output Driver Control . . . . .               | 9-5 [1]        |

## Table Of Contents

|           |                                                                    |                 |
|-----------|--------------------------------------------------------------------|-----------------|
| 9.2       | Port Register Description . . . . .                                | 9-6 [1]         |
| 9.2.1     | Pad Driver Control . . . . .                                       | 9-6 [1]         |
| 9.2.2     | Port Output Register . . . . .                                     | 9-9 [1]         |
| 9.2.3     | Port Output Modification Register . . . . .                        | 9-10 [1]        |
| 9.2.4     | Port Input Register . . . . .                                      | 9-12 [1]        |
| 9.2.5     | Port Input/Output Control Registers . . . . .                      | 9-13 [1]        |
| 9.2.6     | Port Digital Input Disable Register . . . . .                      | 9-16 [1]        |
| 9.3       | Port Description . . . . .                                         | 9-17 [1]        |
| 9.3.1     | Port 0 . . . . .                                                   | 9-18 [1]        |
| 9.3.2     | Port 1 . . . . .                                                   | 9-19 [1]        |
| 9.3.3     | Port 2 . . . . .                                                   | 9-20 [1]        |
| 9.3.4     | Port 3 . . . . .                                                   | 9-22 [1]        |
| 9.3.5     | Port 4 . . . . .                                                   | 9-23 [1]        |
| 9.3.6     | Port 5 . . . . .                                                   | 9-24 [1]        |
| 9.3.7     | Port 6 . . . . .                                                   | 9-25 [1]        |
| 9.3.8     | Port 7 . . . . .                                                   | 9-26 [1]        |
| 9.3.9     | Port 8 . . . . .                                                   | 9-27 [1]        |
| 9.3.10    | Port 9 . . . . .                                                   | 9-28 [1]        |
| 9.3.11    | Port 10 . . . . .                                                  | 9-29 [1]        |
| 9.3.12    | Port 11 . . . . .                                                  | 9-31 [1]        |
| 9.3.13    | Port 15 . . . . .                                                  | 9-32 [1]        |
| 9.4       | Pin Description . . . . .                                          | 9-33 [1]        |
| <b>10</b> | <b>Dedicated Pins . . . . .</b>                                    | <b>10-1 [1]</b> |
| <b>11</b> | <b>External Bus Controller (EBC) . . . . .</b>                     | <b>11-1 [1]</b> |
| 11.1      | Summary of Features . . . . .                                      | 11-1 [1]        |
| 11.2      | Overview . . . . .                                                 | 11-1 [1]        |
| 11.3      | Naming Conventions . . . . .                                       | 11-2 [1]        |
| 11.4      | Timing Description . . . . .                                       | 11-2 [1]        |
| 11.4.1    | Bus Phases . . . . .                                               | 11-2 [1]        |
| 11.4.2    | Demultiplexed Bus . . . . .                                        | 11-5 [1]        |
| 11.4.3    | Multiplexed Bus . . . . .                                          | 11-6 [1]        |
| 11.4.4    | Fastest Access Cycles . . . . .                                    | 11-7 [1]        |
| 11.5      | Address Windows . . . . .                                          | 11-9 [1]        |
| 11.5.1    | Window Allocation . . . . .                                        | 11-9 [1]        |
| 11.5.2    | Window Overlap . . . . .                                           | 11-10 [1]       |
| 11.6      | Ready Controlled Bus Access . . . . .                              | 11-11 [1]       |
| 11.6.1    | Enabling the Ready Control . . . . .                               | 11-11 [1]       |
| 11.6.2    | Synchronous and Asynchronous READY . . . . .                       | 11-11 [1]       |
| 11.6.3    | Combining the READY function with predefined wait states . . . . . | 11-12 [1]       |
| 11.7      | External Bus Arbitration . . . . .                                 | 11-13 [1]       |
| 11.7.1    | Initialization of Arbitration . . . . .                            | 11-13 [1]       |
| 11.7.2    | Arbitration Master Scheme . . . . .                                | 11-13 [1]       |

**Table Of Contents**

|           |                                                          |                 |
|-----------|----------------------------------------------------------|-----------------|
| 11.7.3    | Arbitration Slave Scheme .....                           | 11-15 [1]       |
| 11.7.4    | Bus Lock Function .....                                  | 11-15 [1]       |
| 11.7.5    | Direct Master Slave Connection .....                     | 11-16 [1]       |
| 11.8      | EBC Idle State .....                                     | 11-17 [1]       |
| 11.9      | Register Description .....                               | 11-18 [1]       |
| 11.9.1    | EBC Mode Registers .....                                 | 11-18 [1]       |
| 11.9.2    | Timing Control Registers .....                           | 11-20 [1]       |
| 11.9.3    | Function Control Registers .....                         | 11-22 [1]       |
| 11.9.4    | Address Window Selection Registers .....                 | 11-23 [1]       |
| 11.10     | EBC Implementation in XC27x5X .....                      | 11-24 [1]       |
| 11.10.1   | Unused Registers .....                                   | 11-24 [1]       |
| 11.10.2   | Access Control to LXBUS Modules .....                    | 11-24 [1]       |
| 11.10.3   | Shutdown Control .....                                   | 11-24 [1]       |
| 11.10.4   | Dedicated Registers .....                                | 11-25 [1]       |
| <b>12</b> | <b>Startup Configuration and Bootstrap Loading .....</b> | <b>12-1 [1]</b> |
| 12.1      | Startup Mode Selection .....                             | 12-1 [1]        |
| 12.2      | Device Status after Startup .....                        | 12-2 [1]        |
| 12.2.1    | Registers modified by the Startup Procedure .....        | 12-2 [1]        |
| 12.2.2    | System Frequency after Startup .....                     | 12-3 [1]        |
| 12.2.3    | Watchdog Timer handling .....                            | 12-4 [1]        |
| 12.2.4    | Startup Error state .....                                | 12-5 [1]        |
| 12.3      | Supported Startup Modes and Options .....                | 12-6 [1]        |
| 12.3.1    | Basic Startup Modes .....                                | 12-7 [1]        |
| 12.3.2    | Startup Modes with Debug Support .....                   | 12-8 [1]        |
| 12.3.3    | Special Startup Features .....                           | 12-11 [1]       |
| 12.4      | Internal Start .....                                     | 12-15 [1]       |
| 12.5      | External Start .....                                     | 12-15 [1]       |
| 12.5.1    | Specific Settings .....                                  | 12-17 [1]       |
| 12.6      | Bootstrap Loading .....                                  | 12-18 [1]       |
| 12.6.1    | General Functionality .....                              | 12-18 [1]       |
| 12.6.2    | Bootstrap Loaders using UART Protocol .....              | 12-20 [1]       |
| 12.6.3    | Synchronous Serial Channel Bootstrap Loader .....        | 12-27 [1]       |
| 12.6.4    | CAN Bootstrap Loader .....                               | 12-30 [1]       |
| 12.6.5    | Summary of Bootstrap Loader Modes .....                  | 12-33 [1]       |
| <b>13</b> | <b>Debug System .....</b>                                | <b>13-1 [1]</b> |
| 13.1      | Debug Interface .....                                    | 13-2 [1]        |
| 13.1.1    | Routing of Debug Signals .....                           | 13-3 [1]        |
| 13.2      | OCDS Module .....                                        | 13-5 [1]        |
| 13.2.1    | Debug Events .....                                       | 13-6 [1]        |
| 13.2.2    | Debug Actions .....                                      | 13-7 [1]        |
| 13.3      | Cerberus .....                                           | 13-8 [1]        |
| 13.3.1    | Functional Overview .....                                | 13-9 [1]        |

**Table Of Contents**

|           |                                                        |                 |
|-----------|--------------------------------------------------------|-----------------|
| 13.4      | Emulation Device . . . . .                             | 13-10 [1]       |
| 13.4.1    | MCDS Use Cases . . . . .                               | 13-10 [1]       |
| 13.4.2    | MCDS Features . . . . .                                | 13-11 [1]       |
| 13.5      | Boundary-Scan . . . . .                                | 13-12 [1]       |
| <b>14</b> | <b>Instruction Set Summary . . . . .</b>               | <b>14-1 [1]</b> |
| <b>15</b> | <b>Device Specification . . . . .</b>                  | <b>15-1 [1]</b> |
| <b>16</b> | <b>The General Purpose Timer Units . . . . .</b>       | <b>16-1 [2]</b> |
| 16.1      | Timer Block GPT1 . . . . .                             | 16-2 [2]        |
| 16.1.1    | GPT1 Core Timer T3 Control . . . . .                   | 16-4 [2]        |
| 16.1.2    | GPT1 Core Timer T3 Operating Modes . . . . .           | 16-8 [2]        |
| 16.1.3    | GPT1 Auxiliary Timers T2/T4 Control . . . . .          | 16-15 [2]       |
| 16.1.4    | GPT1 Auxiliary Timers T2/T4 Operating Modes . . . . .  | 16-19 [2]       |
| 16.1.5    | GPT1 Clock Signal Control . . . . .                    | 16-28 [2]       |
| 16.1.6    | GPT1 Timer Registers . . . . .                         | 16-31 [2]       |
| 16.1.7    | Interrupt Control for GPT1 Timers . . . . .            | 16-32 [2]       |
| 16.2      | Timer Block GPT2 . . . . .                             | 16-33 [2]       |
| 16.2.1    | GPT2 Core Timer T6 Control . . . . .                   | 16-35 [2]       |
| 16.2.2    | GPT2 Core Timer T6 Operating Modes . . . . .           | 16-39 [2]       |
| 16.2.3    | GPT2 Auxiliary Timer T5 Control . . . . .              | 16-42 [2]       |
| 16.2.4    | GPT2 Auxiliary Timer T5 Operating Modes . . . . .      | 16-45 [2]       |
| 16.2.5    | GPT2 Register CAPREL Operating Modes . . . . .         | 16-49 [2]       |
| 16.2.6    | GPT2 Clock Signal Control . . . . .                    | 16-55 [2]       |
| 16.2.7    | GPT2 Timer Registers . . . . .                         | 16-58 [2]       |
| 16.2.8    | Interrupt Control for GPT2 Timers and CAPREL . . . . . | 16-59 [2]       |
| 16.3      | Miscellaneous Registers . . . . .                      | 16-60 [2]       |
| 16.4      | Interfaces of the GPT Module . . . . .                 | 16-65 [2]       |
| <b>17</b> | <b>Real Time Clock . . . . .</b>                       | <b>17-1 [2]</b> |
| 17.1      | Defining the RTC Time Base . . . . .                   | 17-2 [2]        |
| 17.2      | RTC Run Control . . . . .                              | 17-5 [2]        |
| 17.3      | RTC Operating Modes . . . . .                          | 17-7 [2]        |
| 17.4      | 48-bit Timer Operation . . . . .                       | 17-11 [2]       |
| 17.5      | System Clock Operation . . . . .                       | 17-11 [2]       |
| 17.6      | Cyclic Interrupt Generation . . . . .                  | 17-12 [2]       |
| 17.7      | RTC Interrupt Generation . . . . .                     | 17-13 [2]       |
| 17.8      | Miscellaneous Registers . . . . .                      | 17-15 [2]       |
| <b>18</b> | <b>Analog to Digital Converter . . . . .</b>           | <b>18-1 [2]</b> |
| 18.1      | Introduction . . . . .                                 | 18-1 [2]        |
| 18.1.1    | ADC Block Diagram . . . . .                            | 18-2 [2]        |
| 18.1.2    | Feature Set . . . . .                                  | 18-3 [2]        |
| 18.1.3    | Abbreviations . . . . .                                | 18-4 [2]        |

**Table Of Contents**

|           |                                                                     |                 |
|-----------|---------------------------------------------------------------------|-----------------|
| 18.1.4    | ADC Kernel Overview . . . . .                                       | 18-5 [2]        |
| 18.1.5    | Conversion Request Unit . . . . .                                   | 18-7 [2]        |
| 18.1.6    | Conversion Result Unit . . . . .                                    | 18-9 [2]        |
| 18.1.7    | Interrupt Structure . . . . .                                       | 18-10 [2]       |
| 18.1.8    | Electrical Models . . . . .                                         | 18-12 [2]       |
| 18.1.9    | Transfer Characteristics and Error Definitions . . . . .            | 18-15 [2]       |
| 18.2      | Operating the ADC . . . . .                                         | 18-16 [2]       |
| 18.2.1    | Register Overview . . . . .                                         | 18-17 [2]       |
| 18.2.2    | Mode Control . . . . .                                              | 18-20 [2]       |
| 18.2.3    | Module Activation and Power Saving Modes . . . . .                  | 18-22 [2]       |
| 18.2.4    | Clocking Scheme . . . . .                                           | 18-23 [2]       |
| 18.2.5    | General ADC Registers . . . . .                                     | 18-24 [2]       |
| 18.2.6    | Request Source Arbiter . . . . .                                    | 18-34 [2]       |
| 18.2.7    | Arbiter Registers . . . . .                                         | 18-39 [2]       |
| 18.2.8    | Scan Request Source Handling . . . . .                              | 18-41 [2]       |
| 18.2.9    | Scan Request Source Registers . . . . .                             | 18-45 [2]       |
| 18.2.10   | Sequential Request Source Handling . . . . .                        | 18-49 [2]       |
| 18.2.11   | Sequential Source Registers . . . . .                               | 18-54 [2]       |
| 18.2.12   | Channel-Related Functions . . . . .                                 | 18-65 [2]       |
| 18.2.13   | Channel-Related Registers . . . . .                                 | 18-70 [2]       |
| 18.2.14   | Conversion Result Handling . . . . .                                | 18-80 [2]       |
| 18.2.15   | Conversion Result-Related Registers . . . . .                       | 18-88 [2]       |
| 18.2.16   | Multiplexer Test Mode for CH7 . . . . .                             | 18-98 [2]       |
| 18.2.17   | External Multiplexer Control . . . . .                              | 18-99 [2]       |
| 18.2.18   | Synchronized Conversions for Parallel Sampling . . . . .            | 18-102 [2]      |
| 18.2.19   | Equidistant Sampling . . . . .                                      | 18-106 [2]      |
| 18.2.20   | Broken Wire Detection . . . . .                                     | 18-108 [2]      |
| 18.2.21   | Additional Feature Registers . . . . .                              | 18-110 [2]      |
| 18.3      | Implementation . . . . .                                            | 18-117 [2]      |
| 18.3.1    | Address Map . . . . .                                               | 18-117 [2]      |
| 18.3.2    | Interrupt Control Registers . . . . .                               | 18-117 [2]      |
| 18.3.3    | Analog Connections . . . . .                                        | 18-119 [2]      |
| 18.3.4    | Digital Connections . . . . .                                       | 18-122 [2]      |
| <b>19</b> | <b>Capture/Compare Unit 2 . . . . .</b>                             | <b>19-1 [2]</b> |
| 19.1      | The CAPCOM2 Timers . . . . .                                        | 19-4 [2]        |
| 19.2      | CAPCOM2 Timer Interrupts . . . . .                                  | 19-10 [2]       |
| 19.3      | Capture/Compare Channels . . . . .                                  | 19-11 [2]       |
| 19.3.1    | Capture/Compare Registers for the CAPCOM2 (CC31 ... CC16) . . . . . | 19-11 [2]       |
| 19.4      | Capture Mode Operation . . . . .                                    | 19-14 [2]       |
| 19.5      | Compare Mode Operation . . . . .                                    | 19-15 [2]       |
| 19.5.1    | Compare Mode 0 . . . . .                                            | 19-16 [2]       |
| 19.5.2    | Compare Mode 1 . . . . .                                            | 19-16 [2]       |

**Table Of Contents**

|           |                                                    |                 |
|-----------|----------------------------------------------------|-----------------|
| 19.5.3    | Compare Mode 2 . . . . .                           | 19-19 [2]       |
| 19.5.4    | Compare Mode 3 . . . . .                           | 19-19 [2]       |
| 19.5.5    | Double-Register Compare Mode . . . . .             | 19-24 [2]       |
| 19.6      | Compare Output Signal Generation . . . . .         | 19-27 [2]       |
| 19.7      | Single Event Operation . . . . .                   | 19-29 [2]       |
| 19.8      | Staggered and Non-Staggered Operation . . . . .    | 19-31 [2]       |
| 19.9      | CAPCOM2 Interrupts . . . . .                       | 19-36 [2]       |
| 19.10     | External Input Signal Requirements . . . . .       | 19-38 [2]       |
| 19.10.1   | Miscellaneous Registers . . . . .                  | 19-39 [2]       |
| 19.11     | Interfaces of the CAPCOM Units . . . . .           | 19-42 [2]       |
| <b>20</b> | <b>Capture/Compare Unit 6 (CCU6) . . . . .</b>     | <b>20-1 [2]</b> |
| 20.1      | Introduction . . . . .                             | 20-1 [2]        |
| 20.1.1    | Feature Set Overview . . . . .                     | 20-2 [2]        |
| 20.1.2    | Block Diagram . . . . .                            | 20-3 [2]        |
| 20.1.3    | Register Overview . . . . .                        | 20-4 [2]        |
| 20.2      | Operating Timer T12 . . . . .                      | 20-7 [2]        |
| 20.2.1    | T12 Overview . . . . .                             | 20-8 [2]        |
| 20.2.2    | T12 Counting Scheme . . . . .                      | 20-10 [2]       |
| 20.2.3    | T12 Compare Mode . . . . .                         | 20-14 [2]       |
| 20.2.4    | Compare Mode Output Path . . . . .                 | 20-21 [2]       |
| 20.2.5    | T12 Capture Modes . . . . .                        | 20-26 [2]       |
| 20.2.6    | T12 Shadow Register Transfer . . . . .             | 20-30 [2]       |
| 20.2.7    | Timer T12 Operating Mode Selection . . . . .       | 20-31 [2]       |
| 20.2.8    | T12 related Registers . . . . .                    | 20-32 [2]       |
| 20.2.9    | Capture/Compare Control Registers . . . . .        | 20-37 [2]       |
| 20.3      | Operating Timer T13 . . . . .                      | 20-49 [2]       |
| 20.3.1    | T13 Overview . . . . .                             | 20-49 [2]       |
| 20.3.2    | T13 Counting Scheme . . . . .                      | 20-52 [2]       |
| 20.3.3    | T13 Compare Mode . . . . .                         | 20-57 [2]       |
| 20.3.4    | Compare Mode Output Path . . . . .                 | 20-59 [2]       |
| 20.3.5    | T13 Shadow Register Transfer . . . . .             | 20-60 [2]       |
| 20.3.6    | T13 related Registers . . . . .                    | 20-62 [2]       |
| 20.4      | Trap Handling . . . . .                            | 20-65 [2]       |
| 20.5      | Multi-Channel Mode . . . . .                       | 20-67 [2]       |
| 20.6      | Hall Sensor Mode . . . . .                         | 20-70 [2]       |
| 20.6.1    | Hall Pattern Evaluation . . . . .                  | 20-71 [2]       |
| 20.6.2    | Hall Pattern Compare Logic . . . . .               | 20-73 [2]       |
| 20.6.3    | Hall Mode Flags . . . . .                          | 20-74 [2]       |
| 20.6.4    | Hall Mode for Brushless DC-Motor Control . . . . . | 20-76 [2]       |
| 20.7      | Modulation Control Registers . . . . .             | 20-78 [2]       |
| 20.7.1    | Modulation Control . . . . .                       | 20-78 [2]       |
| 20.7.2    | Trap Control Register . . . . .                    | 20-80 [2]       |

## Table Of Contents

|           |                                                       |                 |
|-----------|-------------------------------------------------------|-----------------|
| 20.7.3    | Passive State Level Register . . . . .                | 20-83 [2]       |
| 20.7.4    | Multi-Channel Mode Registers . . . . .                | 20-84 [2]       |
| 20.8      | Interrupt Handling . . . . .                          | 20-89 [2]       |
| 20.8.1    | Interrupt Structure . . . . .                         | 20-89 [2]       |
| 20.8.2    | Interrupt Registers . . . . .                         | 20-91 [2]       |
| 20.9      | General Module Operation . . . . .                    | 20-103 [2]      |
| 20.9.1    | Mode Control . . . . .                                | 20-103 [2]      |
| 20.9.2    | Input Selection . . . . .                             | 20-106 [2]      |
| 20.9.3    | General Registers . . . . .                           | 20-107 [2]      |
| 20.10     | Implementation . . . . .                              | 20-115 [2]      |
| 20.10.1   | Address Map . . . . .                                 | 20-115 [2]      |
| 20.10.2   | Interrupt Control Registers . . . . .                 | 20-116 [2]      |
| 20.10.3   | Synchronous Start Feature . . . . .                   | 20-117 [2]      |
| 20.10.4   | Digital Connections . . . . .                         | 20-118 [2]      |
| <b>21</b> | <b>Universal Serial Interface Channel . . . . .</b>   | <b>21-1 [2]</b> |
| 21.1      | Introduction . . . . .                                | 21-1 [2]        |
| 21.1.1    | Feature Set Overview . . . . .                        | 21-2 [2]        |
| 21.1.2    | Channel Structure . . . . .                           | 21-5 [2]        |
| 21.1.3    | Input Stages . . . . .                                | 21-6 [2]        |
| 21.1.4    | Output Signals . . . . .                              | 21-7 [2]        |
| 21.1.5    | Baud Rate Generator . . . . .                         | 21-8 [2]        |
| 21.1.6    | Channel Events and Interrupts . . . . .               | 21-9 [2]        |
| 21.1.7    | Data Shifting and Handling . . . . .                  | 21-9 [2]        |
| 21.2      | Operating the USIC . . . . .                          | 21-13 [2]       |
| 21.2.1    | Register Overview . . . . .                           | 21-13 [2]       |
| 21.2.2    | Operating the USIC Communication Channel . . . . .    | 21-18 [2]       |
| 21.2.3    | Channel Control and Configuration Registers . . . . . | 21-25 [2]       |
| 21.2.4    | Protocol Related Registers . . . . .                  | 21-33 [2]       |
| 21.2.5    | Operating the Input Stages . . . . .                  | 21-36 [2]       |
| 21.2.6    | Input Stage Register . . . . .                        | 21-38 [2]       |
| 21.2.7    | Operating the Baud Rate Generator . . . . .           | 21-41 [2]       |
| 21.2.8    | Baud Rate Generator Registers . . . . .               | 21-46 [2]       |
| 21.2.9    | Operating the Transmit Data Path . . . . .            | 21-51 [2]       |
| 21.2.10   | Operating the Receive Data Path . . . . .             | 21-55 [2]       |
| 21.2.11   | Transfer Control and Status Registers . . . . .       | 21-57 [2]       |
| 21.2.12   | Data Buffer Registers . . . . .                       | 21-69 [2]       |
| 21.2.13   | Operating the FIFO Data Buffer . . . . .              | 21-79 [2]       |
| 21.2.14   | FIFO Buffer and Bypass Registers . . . . .            | 21-89 [2]       |
| 21.3      | Asynchronous Serial Channel (ASC = UART) . . . . .    | 21-110 [2]      |
| 21.3.1    | Signal Description . . . . .                          | 21-110 [2]      |
| 21.3.2    | Frame Format . . . . .                                | 21-111 [2]      |
| 21.3.3    | Operating the ASC . . . . .                           | 21-114 [2]      |

**Table Of Contents**

|           |                                                                |            |
|-----------|----------------------------------------------------------------|------------|
| 21.3.4    | ASC Protocol Registers . . . . .                               | 21-123 [2] |
| 21.3.5    | Hardware LIN Support . . . . .                                 | 21-129 [2] |
| 21.4      | Synchronous Serial Channel (SSC) . . . . .                     | 21-131 [2] |
| 21.4.1    | Signal Description . . . . .                                   | 21-131 [2] |
| 21.4.2    | Operating the SSC . . . . .                                    | 21-139 [2] |
| 21.4.3    | Operating the SSC in Master Mode . . . . .                     | 21-143 [2] |
| 21.4.4    | Operating the SSC in Slave Mode . . . . .                      | 21-150 [2] |
| 21.4.5    | SSC Protocol Registers . . . . .                               | 21-152 [2] |
| 21.4.6    | SSC Timing Considerations . . . . .                            | 21-158 [2] |
| 21.5      | Inter-IC Bus Protocol (IIC) . . . . .                          | 21-161 [2] |
| 21.5.1    | Introduction . . . . .                                         | 21-161 [2] |
| 21.5.2    | Operating the IIC . . . . .                                    | 21-165 [2] |
| 21.5.3    | Symbol Timing . . . . .                                        | 21-171 [2] |
| 21.5.4    | Data Flow Handling . . . . .                                   | 21-174 [2] |
| 21.5.5    | IIC Protocol Registers . . . . .                               | 21-179 [2] |
| 21.6      | IIS Protocol . . . . .                                         | 21-185 [2] |
| 21.6.1    | Introduction . . . . .                                         | 21-185 [2] |
| 21.6.2    | Operating the IIS . . . . .                                    | 21-189 [2] |
| 21.6.3    | Operating the IIS in Master Mode . . . . .                     | 21-194 [2] |
| 21.6.4    | Operating the IIS in Slave Mode . . . . .                      | 21-198 [2] |
| 21.6.5    | IIS Protocol Registers . . . . .                               | 21-199 [2] |
| 21.7      | USIC Implementation in XC27x5X . . . . .                       | 21-205 [2] |
| 21.7.1    | Implementation Overview . . . . .                              | 21-205 [2] |
| 21.7.2    | Channel Features . . . . .                                     | 21-206 [2] |
| 21.7.3    | Address Map . . . . .                                          | 21-207 [2] |
| 21.7.4    | Module Identification Registers . . . . .                      | 21-208 [2] |
| 21.7.5    | Interrupt Control Registers . . . . .                          | 21-210 [2] |
| 21.7.6    | Input/Output Connections . . . . .                             | 21-212 [2] |
| <b>22</b> | <b>Controller Area Network (MultiCAN) Controller</b> . . . . . | 22-1 [2]   |
| 22.1      | MultiCAN Short Description . . . . .                           | 22-1 [2]   |
| 22.1.1    | Overview . . . . .                                             | 22-1 [2]   |
| 22.1.2    | CAN Features . . . . .                                         | 22-2 [2]   |
| 22.2      | CAN Functional Description . . . . .                           | 22-3 [2]   |
| 22.2.1    | Conventions and Definitions . . . . .                          | 22-3 [2]   |
| 22.2.2    | Introduction . . . . .                                         | 22-3 [2]   |
| 22.2.3    | CAN Node Control . . . . .                                     | 22-9 [2]   |
| 22.2.4    | Message Object List Structure . . . . .                        | 22-13 [2]  |
| 22.2.5    | CAN Node Analysis Features . . . . .                           | 22-18 [2]  |
| 22.2.6    | Message Acceptance Filtering . . . . .                         | 22-21 [2]  |
| 22.2.7    | Message Postprocessing Interface . . . . .                     | 22-24 [2]  |
| 22.2.8    | Message Object Data Handling . . . . .                         | 22-28 [2]  |
| 22.2.9    | Message Object Functionality . . . . .                         | 22-35 [2]  |

**Table Of Contents**

|        |                                                               |            |
|--------|---------------------------------------------------------------|------------|
| 22.3   | MultiCAN Kernel Registers . . . . .                           | 22-44 [2]  |
| 22.3.1 | Register Address Map . . . . .                                | 22-44 [2]  |
| 22.3.2 | Global MultiCAN Registers . . . . .                           | 22-49 [2]  |
| 22.3.3 | CAN Node Specific Registers . . . . .                         | 22-62 [2]  |
| 22.3.4 | Message Object Registers . . . . .                            | 22-79 [2]  |
| 22.4   | General Control and Status . . . . .                          | 22-102 [2] |
| 22.4.1 | Clock Control . . . . .                                       | 22-102 [2] |
| 22.4.2 | Port Input Control . . . . .                                  | 22-103 [2] |
| 22.4.3 | Suspend Mode . . . . .                                        | 22-104 [2] |
| 22.4.4 | Interrupt Structure . . . . .                                 | 22-105 [2] |
| 22.5   | MultiCAN Module Implementation . . . . .                      | 22-106 [2] |
| 22.5.1 | Interfaces of the CAN Module . . . . .                        | 22-106 [2] |
| 22.5.2 | Module Clock Generation . . . . .                             | 22-107 [2] |
| 22.5.3 | Mode Control Behavior . . . . .                               | 22-116 [2] |
| 22.5.4 | Mode Control . . . . .                                        | 22-117 [2] |
| 22.5.5 | Mode Control Register Description . . . . .                   | 22-119 [2] |
| 22.5.6 | Connection of External Signals . . . . .                      | 22-122 [2] |
| 22.5.7 | MultiCAN Module Register Address Map . . . . .                | 22-127 [2] |
| 23     | <b>Appendix: Functional and Operational Updates</b> . . . . . | 23-1 [2]   |
|        | <b>Keyword Index</b> . . . . .                                | 24-1 [2]   |
|        | <b>Register Index</b> . . . . .                               | 25-8 [2]   |

## Introduction

### 1 Introduction

The rapidly growing area of embedded control applications is representing one of the most time-critical operating environments for today's microcontrollers. Complex control algorithms have to be processed based on a large number of digital as well as analog input signals, and the appropriate output signals must be generated within a defined maximum response time. Embedded control applications also are often sensitive to board space, power consumption, and overall system cost.

Embedded control applications therefore require microcontrollers, which:

- offer a high level of system integration
- eliminate the need for additional peripheral devices and the associated software overhead
- provide system security and fail-safe mechanisms
- provide effective means to control (and reduce) the device's power consumption

The increasing complexity of embedded control applications requires microcontrollers for new high-end embedded control systems to possess a significant CPU performance and peripheral functionality. To achieve this high performance goal, Infineon has decided to develop its families of 16/32-bit CMOS microcontrollers without the constraints of backward compatibility with previous architectures.

Nonetheless the architectures of these microcontroller families pursue successful hardware and software concepts, which have been established in Infineon's popular 8-bit controller families, while delivering 32-bit performance.

This established functionality, which has been the basis for system solutions in a wide range of application areas, is amended with flexible peripheral modules and effective power control features. The sum of this provides the prerequisites for powerful, yet efficient systems-on-chip.

### Solutions for PowerTrain Systems

The XC27x5X derivatives address the increasing requirements for value, performance, and features in PowerTrain applications. The combination of 32-bit features with the well established C166SV2 core supports competitive engine- and transmission-applications:

- The scalable XC27x5X product portfolio fits perfectly to your requirements
- Compatibility provides easy adaptation to changing requirements in performance and functionality
- 32-bit (system) performance and features ensure long term usability
- Flexible peripherals such as USIC, MultiCAN, ADC maximize re-use across your developments
- Enhanced value through single voltage supply and embedded voltage regulator

Soon to come variants enlarging the portfolio, and Infineon's high quality standards make the XC27x5X Controllers an ideal choice for performing and upgradable systems.

## **Introduction**

### **About this Manual**

This manual describes the functionality of a number of microcontroller types of the Infineon XC2000 Family, the XC27x5X derivatives.

These microcontrollers provide identical functionality to a large extent, but each device type has specific unique features as indicated here.

The descriptions in this manual cover a superset of the provided features.

A detailed list of features of the various derivatives is provided in the Data Sheets of these products.

This manual is valid for these derivatives and describes all variations of the different available temperature ranges and packages.

For simplicity, these various device types are referred to by the collective term **XC27x5X** throughout this manual. The complete Pro Electron conforming designations are listed in the respective Data Sheets.

Some sections of this manual do not refer to all of the XC27x5X derivatives which are currently available or planned (such as devices with different types of on-chip memory or peripherals). These sections contain respective notes wherever possible.

## Introduction

### 1.1 Members of the 16/32-bit Microcontroller Families

The microcontrollers in the Infineon 16/32-bit family have been designed to meet the high performance requirements of real-time embedded control applications. The architecture of this family has been optimized for high instruction throughput and minimized response time to external stimuli (interrupts). Intelligent peripheral subsystems have been integrated to reduce the need for CPU intervention to a minimum extent. This also minimizes the need for communication via the external bus interface. The high flexibility of this architecture allows to serve the diverse and varying needs of different application areas such as automotive, industrial control, or data communications.

The core of the 16-bit family has been developed with a modular family concept in mind. All family members execute an efficient control-optimized instruction set (additional instructions for members of the second generation). This allows easy and quick implementation of new family members with different internal memory sizes and technologies, different sets of on-chip peripherals, and/or different numbers of IO pins.

The XBUS/LXBus concept (internal representation of the external bus interface) provides a straightforward path for building application-specific derivatives by integrating application-specific peripheral modules with the standard on-chip peripherals.

As programs for embedded control applications become larger, high level languages are favored by programmers. High level language programs are easier to write, to debug and to maintain. The C166 Family supports this starting with its 2<sup>nd</sup> generation.

The 80C166-type microcontrollers were the **first generation** of the 16-bit controller family. These devices established the C166 architecture.

The C165-type and C167-type devices are members of the **second generation** of this family. This second generation is even more powerful due to additional instructions for HLL support, an increased address space, increased internal RAM, and highly efficient management of various resources on the external bus.

**Enhanced derivatives** of this second generation provide more features such as additional internal high-speed RAM, an integrated CAN-Module, an on-chip PLL, etc.

The design of more efficient systems may require the integration of application-specific peripherals to boost system performance while minimizing the part count. These efforts are supported by the XBUS, defined for the Infineon 16-bit microcontrollers (second generation). The XBUS is an internal representation of the external bus interface which opens and simplifies the integration of peripherals by standardizing the required interface. One representative taking advantage of this technology is the integrated CAN module.

The C165-type devices are reduced functionality versions of the C167 because they do not have the A/D converter, the CAPCOM units, and the PWM module. This results in a smaller package, reduced power consumption, and design savings.

## Introduction

The C164-type devices, the C167CS derivatives, and some of the C161-type devices are further enhanced by a flexible power management and form the **third generation** of the 16-bit controller family. This power management mechanism provides an effective means to control the power that is consumed in a certain state of the controller and thus minimizes the overall power consumption for a given application.

The XC16x derivatives represent the **fourth generation** of the 16-bit controller family. The XC166 Family dramatically increases the performance of 16-bit microcontrollers by several major improvements and additions. The MAC-unit adds DSP-functionality to handle digital filter algorithms and greatly reduces the execution time of multiplications and divisions. It also adds 32-bit operations and a 40-bit accumulator. The 5-stage pipeline, single-cycle execution of most instructions, and PEC-transfers within the complete addressing range increase system performance. The previous XBUS is replaced by the optimized LXBus. Debugging the target system is supported by integrated functions for On-Chip Debug Support (OCDS).

The present XC2000 Family of microcontrollers builds the **fifth generation** of 16-bit microcontrollers which provides 32-bit performance and takes users and applications a considerable step towards industry's target of systems on chip. Integrated memories and peripherals allow compact systems, the integrated core power supply and control reduces system requirements to one single voltage supply, the powerful combination of CPU and MAC-unit is unleashed by optimized compilers. This leaves no performance gap towards 32-bit systems.

Also there are devices with specific functional units.

The devices may be offered in different packages, temperature ranges and speed classes.

Additional standard and application-specific derivatives are planned and are in development.

*Note: Not all derivatives will be offered in all temperature ranges, speed classes, packages, or program memory variations.*

Information about specific versions and derivatives will be made available with the devices themselves. Contact your Infineon representative for up-to-date material or refer to <http://www.infineon.com/microcontrollers>.

*Note: As the architecture and the basic features, such as the CPU core and built-in peripherals, are identical for most of the currently offered versions of the XC27x5X, descriptions within this manual that refer to the "XC27x5X" also apply to the other variations, unless otherwise noted.*

## Introduction

### 1.2 Summary of Basic Features

The XC27x5X devices are enhanced members of the Infineon XC2000 Family of full featured single-chip CMOS microcontrollers.

*Note: The various derivates are referred to as XC27x5X throughout this manual.*

The XC27x5X combines the extended functionality and performance of the C166SV2 Core with powerful on-chip peripheral subsystems and on-chip memory units and provides several means for power reduction.

The following key features contribute to the high performance of the XC27x5X:

#### Intelligent On-Chip Peripheral Subsystems

- Two synchronizable A/D Converters with programmable resolution (10-bit or 8-bit) and conversion time (down to below 1  $\mu$ s), up to 24 analog input channels, auto scan modes, channel injection, data reduction features
- One Capture/Compare Unit with 2 independent time bases, very flexible PWM unit/event recording unit with different operating modes, includes two 16-bit timers/counters, maximum resolution  $f_{SYS}$
- Up to four Capture/Compare Units for flexible PWM Signal Generation (CCU6) (3/6 Capture/Compare Channels and 1 Compare Channel)
- Two Multifunctional General Purpose Timer Units:
  - GPT1: three 16-bit timers/counters, maximum resolution  $f_{SYS}/4$
  - GPT2: two 16-bit timers/counters, maximum resolution  $f_{SYS}/2$
- Eight Serial Channels with baud rate generator, receive/transmit FIFOs, programmable data length and shift direction, usable as UART, SPI-like, IIC, IIS, and LIN interface
- Controller Area Network (MultiCAN) Module, Rev. 2.0B active, two nodes operating independently or exchanging data via a gateway function, Full-CAN/Basic-CAN
- Real Time Clock with alarm interrupt
- Watchdog Timer with programmable time intervals
- Bootstrap Loaders for flexible system initialization
- Protection management for system configuration and control registers

#### Integrated On-Chip Memories

- 8 Kbytes on-chip Stand-By RAM (SBRAM) for data
- 2 Kbytes Dual-Port RAM (DPRAM) for variables, register banks, and stacks
- 16 Kbytes on-chip high-speed Data SRAM (DSRAM) for variables and stacks
- Up to 32 Kbytes on-chip high-speed Program/Data SRAM (PSRAM) for code and data
- Up to 832 Kbytes on-chip Flash Program Memory for instruction code or constant data

*Note: The system stack can be located in any memory area within the complete addressing range.*

## Introduction

### High Performance 16-bit CPU with Five-Stage Pipeline and MAC Unit

- Single clock cycle instruction execution
- 1 cycle minimum instruction cycle time (most instructions)
- 1 cycle multiplication (16-bit × 16-bit)
- 4 + 17 cycles division (32-bit / 16-bit), 4 cycles delay, 17 cycles background execution
- 1 cycle multiply and accumulate instruction (MAC) execution
- 32-bit addition and 32-bit subtraction (MAC unit)
- 40-bit barrel shifter and 40-bit accumulator
- Automatic saturation or rounding included
- Multiple high bandwidth internal data buses
- Register-based design with multiple, variable register banks
- Two additional fast register banks
- Fast context switching support
- 16 Mbytes of linear address space for code and data (von Neumann architecture)
- System stack cache support with automatic stack overflow/underflow detection
- High performance branch, call, and loop processing
- Zero-cycle jump execution

### Control Oriented Instruction Set with High Efficiency

- Bit, byte, and word data types
- Flexible and efficient addressing modes for high code density
- Enhanced boolean bit manipulation with direct addressability of 6 Kbits for peripheral control and user-defined flags
- Hardware traps to identify exception conditions during runtime
- HLL support for semaphore operations and efficient data access

### Power Management Features

- Two IO power domains fulfill system requirements from 3 V to 5 V
- Gated clock concept for improved power consumption and EMC
- Programmable system slowdown via clock generation unit
- Flexible management of peripherals, can be individually disabled
- Programmable frequency output

### 16-Priority-Level Interrupt System

- 96 interrupt nodes with separate interrupt vectors on 15 priority levels (8 group levels)
- 7 cycles minimum interrupt latency in case of internal program execution
- Fast external interrupts
- Programmable external interrupt source selection
- Programmable vector table (start location and step-width)

## Introduction

### 8-Channel Peripheral Event Controller (PEC)

- Interrupt driven single cycle data transfer
- Programmable PEC interrupt request level, (15 down to 8)
- Transfer count option  
(standard CPU interrupt after programmable number of PEC transfers)
- Separate interrupt level for PEC termination interrupts selectable
- Overhead from saving and restoring system state for interrupt requests eliminated
- Full 24-bit addresses for source and destination pointers, supporting transfers within the total address space

### On-Chip Debug Support

- Communication through DAP interface (2-wire) or JTAG interface (5-wire)
- On-chip debug controller with optional break interface
- Hardware, software and external pin breakpoints
- Up to 4 instruction pointer breakpoints
- Debug event control, e.g. with monitor call or CPU halt or trigger of data transfer
- Dedicated DEBUG instructions with control via DAP/JTAG interface
- Access to any internal register or memory location via DAP/JTAG interface
- Single step support and watchpoints with MOV-injection

### Input/Output Lines With Individual Bit Addressability

- Tri-stated in input mode
- Push/pull or open drain output mode
- Programmable port driver control
- Two I/O power domains with a supply voltage range from 3.0 V to 5.5 V  
(core-logic and oscillator input voltage is 1.5 V)

### Various Temperature Ranges

- -40 to +85 °C
- -40 to +125 °C<sup>1)</sup>

### Infineon CMOS Process

- Low power CMOS technology enables power saving modes with flexible power management.

### Green Plastic Low-Profile Quad Flat Pack (LQFP) Packages

- PG-LQFP-144, 20 × 20 mm body, 0.5 mm (19.7 mil) lead spacing,  
surface mount technology

<sup>1)</sup> Not all derivatives are offered in all temperature ranges.

## Introduction

- PG-LQFP-100, 14 × 14 mm body, 0.5 mm (19.7 mil) lead spacing, surface mount technology
- PG-LQFP-64, 10 × 10 mm body, 0.5 mm (19.7 mil) lead spacing, surface mount technology

### Complete Development Support

For the development tool support of its microcontrollers, Infineon collaborates with third party tool suppliers. There is a wide range of tool suppliers world-wide, ranging from local niche manufacturers to multinational companies with broad product portfolios, offering powerful development tools for the complete variety of Infineon microcontroller families, providing a remarkable selection of price-performance classes as well as early availability of high quality key tools such as compilers, assemblers, simulators, debuggers or in-circuit emulators.

Infineon incorporates its strategic tool partners very early into the product development process, making sure embedded system developers get reliable, well-tuned tool solutions, which help them unleash the power of Infineon microcontrollers in the most effective way and with the shortest possible learning curve.

The tool environment for the Infineon 16-bit microcontrollers includes the following tools:

- Compilers (C/C++)
- Macro-assemblers, linkers, locators, library managers, format-converters
- Architectural simulators
- HLL debuggers
- Real-time operating systems
- In-circuit emulators
- Logic analyzer disassemblers
- Starter kits and evaluation boards
- Chip configuration code generation tool (DAvE)

### 1.3 Abbreviations

The following acronyms and terms are used within this document:

|        |                                                     |
|--------|-----------------------------------------------------|
| ADC    | Analog Digital Converter                            |
| ALE    | Address Latch Enable                                |
| ALU    | Arithmetic and Logic Unit                           |
| ASC    | Asynchronous/synchronous Serial Channel             |
| CAN    | Controller Area Network (License Bosch)             |
| CAPCOM | CAPture and COMpare unit                            |
| CISC   | Complex Instruction Set Computing                   |
| CMOS   | Complementary Metal Oxide Silicon                   |
| CPU    | Central Processing Unit                             |
| DAP    | Device Access Port                                  |
| DMU    | Data Management Unit                                |
| EBC    | External Bus Controller                             |
| ESFR   | Extended Special Function Register                  |
| EVVR   | Embedded Validated Voltage Regulator                |
| Flash  | Non-volatile memory that may be electrically erased |
| GPR    | General Purpose Register                            |
| GPT    | General Purpose Timer unit                          |
| HLL    | High Level Language                                 |
| IIC    | Inter Integrated Circuit (Bus)                      |
| IIS    | Inter Integrated Circuit Sound (Bus)                |
| IO     | Input/Output                                        |
| JTAG   | Joint Test Access Group                             |
| LIN    | Local Interconnect Network                          |
| LPR    | Low Power Reference                                 |
| LQFP   | Low Profile Quad Flat Pack                          |
| LXBus  | Internal representation of the external bus         |
| MAC    | Multiply/Accumulate (unit)                          |
| MPU    | Memory Protection Unit                              |
| OCDS   | On-Chip Debug Support                               |

## Introduction

|      |                                             |
|------|---------------------------------------------|
| OTP  | One-Time Programmable memory                |
| PEC  | Peripheral Event Controller                 |
| PLA  | Programmable Logic Array                    |
| PLL  | Phase Locked Loop                           |
| PMU  | Program Management Unit                     |
| PVC  | Power Validation Circuit                    |
| PWM  | Pulse Width Modulation                      |
| RAM  | Random Access Memory                        |
| RISC | Reduced Instruction Set Computing           |
| ROM  | Read Only Memory                            |
| RTC  | Real Time Clock                             |
| SFR  | Special Function Register                   |
| SSC  | Synchronous Serial Channel                  |
| SWD  | Supply Watchdog                             |
| UART | Universal Asynchronous Receiver/Transmitter |
| USIC | Universal Serial Interface Channel          |

### 1.4 Naming Conventions

The diverse bitfields used for control functions and status indication and the registers housing them are equipped with unique names wherever applicable. Thereby these control structures can be referred to by their names rather than by their location. This makes the descriptions by far more comprehensible.

To describe regular structures (such as ports) indices are used instead of a plethora of similar bit names, so bit 3 of port 5 is referred to as P5.3.

Where it helps to clarify the relation between several named structures, the next higher level is added to the respective name to make it unambiguous.

The term ADC0\_GLOBCTR clearly identifies register GLOBCTR as part of module ADC0, the term SYSCON0.CLKSEL clearly identifies bitfield CLKSEL as part of register SYSCON0.

## 2 Architectural Overview

The architecture of the XC27x5X core combines the advantages of both RISC and CISC processors in a very well-balanced way. This computing and controlling power is completed by the DSP-functionality of the MAC-unit. The XC27x5X integrates this powerful CPU core with a set of powerful peripheral units into one chip and connects them very efficiently. On-chip memory blocks with dedicated buses and control units store code and data. This combination of features results in a high performance microcontroller, which is the right choice not only for today's applications, but also for future engineering challenges. One of the buses used concurrently on the XC27x5X is the LXBus, an internal representation of the external bus interface. This bus provides a standardized method for integrating additional application-specific peripherals into derivatives of the standard XC27x5X.



Figure 2-1 XC27x5X Functional Block Diagram

## Architectural Overview

## 2.1 Basic CPU Concepts and Optimizations

The main core of the CPU consists of a set of optimized functional units including the instruction fetch/processing pipelines, a 16-bit Arithmetic and Logic Unit (ALU), a 40-bit Multiply and Accumulate Unit (MAC), an Address and Data Unit (ADU), an Instruction Fetch Unit (IFU), a Register File (RF), and dedicated Special Function Registers (SFRs).

Single clock cycle execution of instructions results in superior CPU performance, while maintaining C166 code compatibility. Impressive DSP performance, concurrent access to different kinds of memories and peripherals boost the overall system performance.



Figure 2-2 CPU Block Diagram

## Summary of CPU Features

- Opcode fully upward compatible with C166 Family
- 2-stage instruction fetch pipeline with FIFO for instruction pre-fetching
- 5-stage instruction execution pipeline
- Pipeline forwarding controls data dependencies in hardware
- Multiple high bandwidth buses for data and instructions
- Linear address space for code and data (von Neumann architecture)
- Nearly all instructions executed in one CPU clock cycle
- Fast multiplication ( $16\text{-bit} \times 16\text{-bit}$ ) in one CPU clock cycle
- Fast background execution of division (32-bit/16-bit) in 21 CPU clock cycles
- Built-in advanced MAC (Multiply Accumulate) Unit:
  - Single cycle MAC instruction with zero cycle latency including a  $16 \times 16$  multiplier
  - 32-bit addition and 32-bit subtraction
  - 40-bit barrel shifter and 40-bit accumulator to handle overflows
  - Automatic saturation to 32 bits or rounding included with the MAC instruction
  - Fractional numbers supported directly
  - One Finite Impulse Response Filter (FIR) tap per cycle with no circular buffer management
- Enhanced boolean bit manipulation facilities
- High performance branch-, call-, and loop-processing
- Zero cycle jump execution
- Register-based design with multiple variable register banks (byte or word operands)
- Two additional fast register banks
- Variable stack with automatic stack overflow/underflow detection
- “Fast interrupt” and “Fast context switch” features
- Built-in memory protection unit (MPU)

The high performance and flexibility of the CPU is achieved by a number of optimized functional blocks (see [Figure 2-2](#)). Optimizations of the functional blocks are described in detail in the following sections.

### 2.1.1 Memory Protection Unit (MPU)

The Memory Protection Unit (MPU) provides the hardware mechanisms needed for implementing memory protection. The MPU allows detection of unauthorized accesses (read, write or instruction fetch) in user-defined memory ranges. It offers protection for the complete address space, including the peripheral area.

The MPU can be used to support the encapsulation of different applications or software components running on the processor. This encapsulation provides the means to ensure integrity and fault isolation capabilities in today's complex systems relying on multiple-sources software.

## Architectural Overview

### 2.1.2 High Instruction Bandwidth/Fast Execution

Based on the hardware provisions, most of the XC27x5X's instructions can be executed in just one clock cycle ( $1/f_{SYS}$ ). This includes arithmetic instructions, logic instructions, and move instructions with most addressing modes.

Special instructions such as JMPS take more than one machine cycle. Divide instructions are mainly executed in the background, so other instructions can be executed in parallel. Due to the prediction mechanism (see [Section 5.2](#)), correctly predicted branch instructions require only one cycle or can even be overlaid with another instruction (zero-cycle jump).

The instruction cycle time is dramatically reduced through the use of instruction pipelining. This technique allows the core CPU to process portions of multiple sequential instruction stages in parallel. Up to seven stages can operate in parallel:

**The two-stage instruction fetch pipeline** fetches and preprocesses instructions from the respective program memory:

**PREFETCH:** Instructions are prefetched from the PMU in the predicted order. The instructions are preprocessed in the branch detection unit to detect branches. The prediction logic determines if branches are assumed to be taken or not.

**FETCH:** The instruction pointer for the next instruction to be fetched is calculated according to the branch prediction rules. The branch folding unit preprocesses detected branches and combines them with the preceding instructions to enable zero-cycle branch execution. Prefetched instructions are stored in the instruction FIFO, while stored instructions are moved from the instruction FIFO to the instruction processing pipeline.

**The five-stage instruction processing pipeline** executes the respective instructions:

**DECODE:** The previously fetched instruction is decoded and the GPR used for indirect addressing is read from the register file, if required.

**ADDRESS:** All operand addresses are calculated. For instructions implicitly accessing the stack the stack pointer (SP) is decremented or incremented.

**MEMORY:** All required operands are fetched.

**EXECUTE:** The specified operation (ALU or MAC) is performed on the previously fetched operands. The condition flags are updated. Explicit write operations to CPU-SFRs are executed. GPRs used for indirect addressing are incremented or decremented, if required.

**WRITE BACK:** The result operands are written to the specified locations. Operands located in the DPRAM are stored via the write-back buffer.

## Architectural Overview

### 2.1.3 Powerful Execution Units

The **16-bit Arithmetic and Logic Unit (ALU)** performs all standard (word) arithmetic and logical operations. Additionally, for byte operations, signals are provided from bits 6 and 7 of the ALU result to set the condition flags correctly. Multiple precision arithmetic is provided through a ‘CARRY-IN’ signal to the ALU from previously calculated portions of the desired operation.

Most internal execution blocks have been optimized to perform operations on either 8-bit or 16-bit quantities. Instructions have been provided as well to allow byte packing in memory while providing sign extension of bytes for word wide arithmetic operations. The internal bus structure also allows transfers of bytes or words to or from peripherals based on the peripheral requirements.

A set of consistent flags is updated automatically in the PSW after each arithmetic, logical, shift, or movement operation. These flags allow branching on specific conditions. Support for both signed and unsigned arithmetic is provided through user-specifiable branch tests. These flags are also preserved automatically by the CPU upon entry into an interrupt or trap routine.

A 16-bit barrel shifter provides multiple bit shifts in a single cycle. Rotates and arithmetic shifts are also supported.

The **Multiply and Accumulate Unit (MAC)** performs extended arithmetic operations such as 32-bit addition, 32-bit subtraction, and single-cycle 16-bit  $\times$  16-bit multiplication. The combined MAC operations (multiplication with cumulative addition/subtraction) represent the major part of the DSP performance of the CPU.

The **Address Data Unit (ADU)** contains two independent arithmetic units to generate, calculate, and update addresses for data accesses. The ADU performs the following major tasks:

- The Standard Address Unit supports linear arithmetic for the short, long, and indirect addressing modes. It also supports data paging and stack handling.
- The DSP Address Generation Unit contains an additional set of address pointers and offset registers which are used in conjunction with the CoXXX instructions only.

The CPU provides a lot of powerful addressing modes for word, byte, and bit data accesses (short, long, indirect). The different addressing modes use different formats and have different scopes.

Dedicated bit processing instructions provide efficient control and testing of peripherals while enhancing data manipulation. These instructions provide direct access to two operands in the bit-addressable space without requiring them to be moved into temporary flags. Logical instructions allow the user to compare and modify a control bit for a peripheral in one instruction. Multiple bit shift instructions (single cycle execution) avoid long instruction streams of single bit shift operations. Bitfield instructions allow the modification of multiple bits from one operand in a single instruction.

## Architectural Overview

### 2.1.4 High Performance Branch-, Call-, and Loop-Processing

Pipelined execution delivers maximum performance with a stream of subsequent instructions. Any disruption requires the pipeline to be refilled and the new instruction to step through the pipeline stages. Due to the high percentage of branching in controller applications, branch instructions have been optimized to require pipeline refilling only in special cases. This is realized by detecting and preprocessing branch instructions in the prefetch stage and by predicting the respective branch target address.

Prefetching then continues from the predicted target address. If the prediction was correct subsequent instructions can be fed to the execution pipeline without a gap, even if a branch is executed, i.e. the code execution is not linear. Branch target prediction (see also [Section 5.2.1](#)) uses the following rules:

- **Unconditional branches:** Branch prediction is trivial in this case, as the branches will always be taken and the target address is defined. This applies to implicitly unconditional branches such as JMPS, CALLR, or RET as well as to branches with condition code “unconditional” such as JMPI cc\_UC.
- **Fixed prediction:** Branch instructions which are often used to realize loops are assumed to be taken if they branch backward to a previous location (the begin of the loop). This applies to conditional branches such as JMPL cc\_XX or JNB.
- **Variable prediction:** In this case the respective prediction (taken or not taken) is coded into the instruction and can, therefore, be selected for each individual branch instruction. Thus, the software designer can optimize the instruction flow to the specific code to be executed<sup>1)</sup>. This applies to the branch instructions JMPA and CALLA.
- **Conditional indirect branches:** These branches are always assumed to be not taken. This applies to branch instructions JMPL cc\_XX, [Rw] and CALLI cc\_XX, [Rw].

The system state information is saved automatically on the internal system stack, thus avoiding the use of instructions to preserve state upon entry and exit of interrupt or trap routines. Call instructions push the value of the IP on the system stack, and require the same execution time as branch instructions. Additionally, instructions have been provided to support indirect branch and call instructions. This feature supports implementation of multiple CASE statement branching in assembler macros and high level languages.

<sup>1)</sup> The programming tools accept either dedicated mnemonics for each prediction leaving the choice up to programmer, or they accept generic mnemonics and apply their own prediction rules.

## Architectural Overview

### 2.1.5 Consistent and Optimized Instruction Formats

To obtain optimum performance in a pipelined design, an instruction set has been designed which incorporates concepts from Reduced Instruction Set Computing (RISC). These concepts primarily allow fast decoding of the instructions and operands while reducing pipeline holds. These concepts, however, do not preclude the use of complex instructions required by microcontroller users. The instruction set was designed to meet the following goals:

- Provide powerful instructions for frequently-performed operations which traditionally have required sequences of instructions. Avoid transfer into and out of temporary registers such as accumulators and carry bits. Perform tasks in parallel such as saving state upon entry into interrupt routines or subroutines.
- Avoid complex encoding schemes by placing operands in consistent fields for each instruction and avoid complex addressing modes which are not frequently used. Consequently, the instruction decode time decreases and the development of compilers and assemblers is simplified.
- Provide most frequently used instructions with one-word instruction formats. All other instructions use two-word formats. This allows all instructions to be placed on word boundaries: this alleviates the need for complex alignment hardware. It also has the benefit of increasing the range for relative branching instructions.

The high performance of the CPU-hardware can be utilized efficiently by a programmer by means of the highly functional XC27x5X instruction set which includes the following instruction classes:

- Arithmetic Instructions
- DSP Instructions
- Logical Instructions
- Boolean Bit Manipulation Instructions
- Compare and Loop Control Instructions
- Shift and Rotate Instructions
- Prioritize Instruction
- Data Movement Instructions
- System Stack Instructions
- Jump and Call Instructions
- Return Instructions
- System Control Instructions
- Miscellaneous Instructions

Possible operand types are bits, bytes, words, and doublewords. Specific instructions support the conversion (extension) of bytes to words. Various direct, indirect, and immediate addressing modes are provided to specify the required operands.

## Architectural Overview

### 2.1.6 Programmable Multiple Priority Interrupt System

The XC27x5X provides 96 separate interrupt nodes that may be assigned to 16 priority levels with 8 group priorities on each level. Most interrupt sources are connected to a dedicated interrupt node. In some cases, multi-source interrupt nodes are incorporated for efficient use of system resources. These nodes can be activated by several source requests and are controlled via interrupt subnode control registers.

The following enhancements within the XC27x5X allow processing of a large number of interrupt sources:

- Peripheral Event Controller (PEC): This processor is used to off-load many interrupt requests from the CPU. It avoids the overhead of entering and exiting interrupt or trap routines by performing single-cycle interrupt-driven byte or word data transfers between any two locations with an optional increment of the PEC source pointer, the destination pointer, or both. Only one cycle is 'stolen' from the current CPU activity to perform a PEC service.
- Multiple Priority Interrupt Controller: This controller allows all interrupts to be assigned any specified priority. Interrupts may also be grouped, which enables the user to prevent similar priority tasks from interrupting each other. For each of the interrupt nodes, there is a separate control register which contains an interrupt request flag, an interrupt enable flag, and an interrupt priority bitfield. After being accepted by the CPU, an interrupt service can be interrupted only by a higher prioritized service request. For standard interrupt processing, each of the interrupt nodes has a dedicated vector location.
- Multiple Register Banks: Two local register banks for immediate context switching add to a relocatable global register bank. The user can specify several register banks located anywhere in the internal DPRAM and made of up to sixteen general purpose registers. A single instruction switches from one register bank to another (switching banks flushes the pipeline, changing the global bank requires a validation sequence).

The XC27x5X is capable of reacting very quickly to non-deterministic events because its interrupt response time is within a very narrow range of typically 7 clock cycles (in the case of internal program execution). Its fast external interrupt inputs are sampled every clock cycle and allow even very short external signals to be recognized.

The XC27x5X also provides an excellent mechanism to identify and process exceptions or error conditions that arise during run-time, so called 'Hardware Traps'. A hardware trap causes an immediate non-maskable system reaction which is similar to a standard interrupt service (branching to a dedicated vector table location). The occurrence of a hardware trap is additionally signified by an individual bit in the trap flag register (TFR). Unless another, higher prioritized, trap service is in progress, a hardware trap will interrupt any current program execution. In turn, a hardware trap service can normally not be interrupted by a standard or PEC interrupt.

Software interrupts are supported by means of the 'TRAP' instruction in combination with an individual trap (interrupt) number.

## Architectural Overview

### 2.1.7 Interfaces to System Resources

The CPU of the XC27x5X interfaces to the system resources via several bus systems which contribute to the overall performance by transferring data concurrently. This avoids stalling the CPU because instructions or operands need to be transferred.

The Dual Port RAM (DPRAM) is directly coupled to the CPU because it houses the global register banks. Transfers from/to these locations affect the performance and are, therefore, carefully optimized.

**The Program Management Unit (PMU)** controls accesses to the on-chip program memory blocks such as the ROM/Flash module and the Program/Data RAM (PSRAM) and also fetches instructions from external memory.

The 64-bit interface between the PMU and the CPU delivers the instruction words, which are requested by the CPU. The PMU decides whether the requested instruction word has to be fetched from on-chip memory or from external memory.

**The Data Management Unit (DMU)** controls accesses to the on-chip Data RAM (DSRAM), to the on-chip peripherals connected to the peripheral bus, and to resources on the external bus. External accesses (including accesses to peripherals connected to the on-chip LXBus) are executed by the External Bus Controller (EBC).

The 16-bit interface between the DMU and the CPU handles all data transfers (operands). Data accesses by the CPU are distributed to the appropriate buses according to the defined address map.

PMU and DMU are directly coupled to perform cross-over transfers with high speed. Crossover transfers are executed in both directions:

- **PMU via DMU:** Code fetches from external locations are redirected via the DMU to EBC. Thus, the XC27x5X can execute code from external resources. No code can be fetched from the Data RAM (DSRAM).
- **DMU via IMB:** Data accesses can also be executed to on-chip resources normally controlled by the PMU. This includes the following types of transfers:
  - Read a constant from the on-chip program ROM/Flash
  - Read data from the on-chip PSRAM
  - Write data to the on-chip PSRAM (required prior to executing out of it)
  - Program/Erase the on-chip Flash memory

## 2.2 On-Chip System Resources

The XC27x5X controllers provide a number of powerful system resources designed around the CPU. The combination of CPU and these resources results in the high performance of the members of this controller family.

### Peripheral Event Controller (PEC) and Interrupt Control

The Peripheral Event Controller enables response to an interrupt request with a single data transfer (word or byte) which consumes only one instruction cycle and does not require saving and restoring the machine status. Each interrupt source is prioritized for every machine cycle in the interrupt control block. If PEC service is selected, a PEC transfer is started. If CPU interrupt service is requested, the current CPU priority level stored in the PSW register is tested to determine whether a higher priority interrupt is currently being serviced. When an interrupt is acknowledged, the current state of the machine is saved on the internal system stack and the CPU branches to the system specific vector for the peripheral.

The PEC contains a set of SFRs which store the count value and control bits for eight data transfer channels. In addition, the PEC uses a dedicated area of RAM which contains the source and destination addresses. The PEC is controlled in a manner similar to any other peripheral: through SFRs containing the desired configuration of each channel.

An individual PEC transfer counter is implicitly decremented for each PEC service except in the continuous transfer mode. When this counter reaches zero, a standard interrupt is performed to the vector location related to the corresponding source. PEC services are very well suited, for example, to moving register contents to/from a memory table. The XC27x5X has eight PEC channels, each of which offers such fast interrupt-driven data transfer capabilities.

### Memory Areas

The memory space of the XC27x5X is configured in a Von Neumann architecture. This means that code memory, data memory, registers, and IO ports are organized within the same linear address space which covers up to 16 Mbytes. The entire memory space can be accessed bytewise or wordwise. Particular portions of the on-chip memory have been made directly bit addressable as well.

*Note: The actual memory sizes depend on the selected device type. This overview describes the maximum block sizes.*

## Architectural Overview

**Up to 832 Kbytes of on-chip Flash memory** store code or constant data. The on-chip Flash memory consists of 4 Flash modules, each built up from 4-Kbyte sectors. Each sector can be separately write protected<sup>1)</sup>, erased and programmed (in blocks of 128 bytes). The complete Flash area can be read-protected. A user-defined password sequence temporarily unlocks protected areas. The Flash modules combine 128-bit read accesses with protected and efficient writing algorithms for programming and erasing. Dynamic error correction provides extremely high read data security for all read accesses. Accesses to different Flash modules can be executed in parallel.

*Note: Program execution from on-chip program memory is the fastest of all possible alternatives and results in maximum performance. The size of the on-chip program memory depends on the chosen derivative. On-chip program memory also includes the PSRAM.*

**Up to 32 Kbytes of on-chip Program SRAM (PSRAM)** are provided to store user code or data. The PSRAM is accessed via the PMU and is, therefore, optimized for code fetches. A section of the PSRAM with programmable size can be write-protected.

**16 Kbytes of on-chip Data SRAM (DSRAM)** are provided as a storage for general user data. The DSRAM is accessed via a separate interface and is, therefore, optimized for data accesses.

**2 Kbytes of on-chip Dual-Port RAM (DPRAM)** are provided as a storage for user defined variables, for the system stack, and in particular for general purpose register banks. A register bank can consist of up to 16 wordwide (R0 to R15) and/or bytewide (RL0, RH0, ..., RL7, RH7) so-called General Purpose Registers (GPRs).

The upper 256 bytes of the DPRAM are directly bitaddressable. When used by a GPR, any location in the DPRAM is bitaddressable.

**8 Kbytes of on-chip Stand-By SRAM (SBRAM)** is provided as a storage for system-relevant user data that must be preserved while the major part of the device is powered down. The SBRAM is accessed via a specific interface and is powered via domain M.

The CPU has an actual register context of up to 16 wordwide and/or bytewide global GPRs at its disposal, which are physically located within the on-chip RAM area. A Context Pointer (CP) register determines the base address of the active global register bank to be accessed by the CPU at a time. The number of register banks is restricted only by the available internal RAM space. For easy parameter passing, a register bank may overlap other register banks.

A system stack of up to 32 Kwords is provided as storage for temporary data. The system stack can be located anywhere within the complete addressing range and it is accessed by the CPU via the Stack Pointer (SP) register and the Stack Pointer Segment (SPSEG) register. Two separate SFRs, STKOV and STKUN, are implicitly compared against the stack pointer value upon each stack access for the detection of a stack overflow or

<sup>1)</sup> To save control bits, sectors are clustered for protection purposes, they remain separate for programming/erasing.

## Architectural Overview

underflow. This mechanism also supports the control of a bigger virtual stack. Maximum performance for stack operations is achieved by allocating the system stack to internal data RAM areas (DPRAM, DSRAM).

Hardware detection of the selected memory space is placed at the internal memory decoders and allows the user to specify any address directly or indirectly and obtain the desired data without using temporary registers or special instructions.

**For Special Function Registers** three areas of the address space are reserved: The standard Special Function Register area (SFR) uses 512 bytes, while the Extended Special Function Register area (ESFR) uses the other 512 bytes. A range of 4 Kbytes is provided for the internal IO area (XSFR). SFRs are wordwide registers which are used for controlling and monitoring functions of the different on-chip units. Unused SFR addresses are reserved for future members of the XC2000 Family with enhanced functionality. Therefore, they should either not be accessed, or written with zeros, to ensure upward compatibility.

In order to meet the needs of designs where more memory is required than is provided on chip, up to 12 Mbytes (approximately, see **Table 2-1**) of external RAM and/or ROM can be connected to the microcontroller. The External Bus Interface also provides access to external peripherals.

**Table 2-1 XC27x5X Memory Map**

| Address Area                         | Start Loc.           | End Loc.             | Area Size <sup>1)</sup> | Notes              |
|--------------------------------------|----------------------|----------------------|-------------------------|--------------------|
| IMB register space                   | FF'FF00 <sub>H</sub> | FF'FFFF <sub>H</sub> | 256 Bytes               | –                  |
| Reserved (Access trap)               | F0'0000 <sub>H</sub> | FF'FEFF <sub>H</sub> | <1 Mbyte                | Minus IMB reg.     |
| Reserved for EPSRAM                  | E8'8000 <sub>H</sub> | EF'FFFF <sub>H</sub> | 480 Kbytes              | Mirrors EPSRAM     |
| Emulated PSRAM                       | E8'0000 <sub>H</sub> | E8'7FFF <sub>H</sub> | 32 Kbytes               | Flash timing       |
| Reserved for PSRAM                   | E0'8000 <sub>H</sub> | E7'FFFF <sub>H</sub> | 480 Kbytes              | Mirrors PSRAM      |
| Program SRAM                         | E0'0000 <sub>H</sub> | E0'7FFF <sub>H</sub> | 32 Kbytes               | Maximum speed      |
| Reserved for pr. mem.                | CC'4000 <sub>H</sub> | DF'FFFF <sub>H</sub> | <1.25 Mbytes            | –                  |
| Program Flash 3                      | CC'0000 <sub>H</sub> | CC'3FFF <sub>H</sub> | 64 Kbytes               | –                  |
| Program Flash 2                      | C8'0000 <sub>H</sub> | CB'FFFF <sub>H</sub> | 256 Kbytes              | –                  |
| Program Flash 1                      | C4'0000 <sub>H</sub> | C7'FFFF <sub>H</sub> | 256 Kbytes              | –                  |
| Program Flash 0                      | C0'0000 <sub>H</sub> | C3'FFFF <sub>H</sub> | 256 Kbytes              | <sup>2)</sup>      |
| External memory area                 | 40'0000 <sub>H</sub> | BF'FFFF <sub>H</sub> | 8 Mbytes                | –                  |
| Available Ext. IO area <sup>3)</sup> | 20'C000 <sub>H</sub> | 3F'FFFF <sub>H</sub> | < 2 Mbytes              | Minus USIC/CAN     |
| MultiCAN/USIC regs.                  | 20'8000 <sub>H</sub> | 20'BFFF <sub>H</sub> | 16 Kbytes               | Alternate location |
| Available Ext. IO area <sup>3)</sup> | 20'6000 <sub>H</sub> | 20'7FFF <sub>H</sub> | 8Kbytes                 | –                  |

**Architectural Overview**
**Table 2-1 XC27x5X Memory Map (cont'd)**

| <b>Address Area</b>  | <b>Start Loc.</b>    | <b>End Loc.</b>      | <b>Area Size<sup>1)</sup></b> | <b>Notes</b>     |
|----------------------|----------------------|----------------------|-------------------------------|------------------|
| USIC registers       | 20'4000 <sub>H</sub> | 20'5FFF <sub>H</sub> | 8 Kbytes                      | Accessed via EBC |
| MultiCAN registers   | 20'0000 <sub>H</sub> | 20'3FFF <sub>H</sub> | 16 Kbytes                     | Accessed via EBC |
| External memory area | 01'0000 <sub>H</sub> | 1F'FFFF <sub>H</sub> | < 2 Mbytes                    | Minus segment 0  |
| SFR area             | 00'FE00 <sub>H</sub> | 00'FFFF <sub>H</sub> | 0.5 Kbyte                     | —                |
| Dual-Port RAM        | 00'F600 <sub>H</sub> | 00'FDFF <sub>H</sub> | 2 Kbytes                      | —                |
| Reserved for DPRAM   | 00'F200 <sub>H</sub> | 00'F5FF <sub>H</sub> | 1 Kbyte                       | —                |
| ESFR area            | 00'F000 <sub>H</sub> | 00'F1FF <sub>H</sub> | 0.5 Kbyte                     | —                |
| XSFR area            | 00'E000 <sub>H</sub> | 00'EFFF <sub>H</sub> | 4 Kbytes                      | —                |
| Data SRAM            | 00'A000 <sub>H</sub> | 00'DFFF <sub>H</sub> | 16 Kbytes                     | —                |
| Reserved for DSRAM   | 00'8000 <sub>H</sub> | 00'9FFF <sub>H</sub> | 8 Kbytes                      | —                |
| External memory area | 00'0000 <sub>H</sub> | 00'7FFF <sub>H</sub> | 32 Kbytes                     | —                |

<sup>1)</sup> The areas marked with “<” are slightly smaller than indicated, see column “Notes”.

<sup>2)</sup> The uppermost 4-Kbyte sector of the first Flash segment is reserved for internal use (C0'F000<sub>H</sub> to C0'FFFF<sub>H</sub>).

<sup>3)</sup> Several pipeline optimizations are not active within the external IO area. This is necessary to control external peripherals properly.

**Note:** For an overview of the available memory sections for the different derivatives, please refer to the corresponding Data Sheets.

## Architectural Overview

### External Bus Interface

To meet the needs of designs where more memory is required than is provided on chip, up to 12 Mbytes of external RAM/ROM/Flash or peripherals can be connected to the XC27x5X microcontroller via its external bus interface.

All of the external memory accesses are performed by a particular on-chip External Bus Controller (EBC). It can be programmed either to Single Chip Mode when no external memory is required, or to an external bus mode with the following possible selections<sup>1)</sup>:

- Address Bus Width with a range of 0 ... 24-bit
- Data Bus Width 8-bit or 16-bit
- Bus Operation Multiplexed or Demultiplexed

In the demultiplexed bus modes, addresses are output on Port 0 and Port 1 and data is input/output on Port 10 and Port 2. In the multiplexed bus modes both addresses and data use Port 10 and Port 2 for input/output. The high order address (segment) lines use Port 2. The number of active address lines is selectable, so the external address space can be restricted. This is required when interface lines are assigned to Port 2.

For up to five address areas the bus mode (multiplexed/demultiplexed), the data bus width (8-bit/16-bit) and even the length of a bus cycle (waitstates, signal delays) can be selected independently. This allows access to a variety of memory and peripheral components directly and with maximum efficiency.

Access to very slow memories or modules with varying access times is supported via a particular 'Ready' function. The active level of the control input signal is selectable.

A HOLD/HLDA protocol is available for bus arbitration and allows the sharing of external resources with other bus masters.

The external bus timing is related to the rising edge of the reference clock output CLKOUT. The external bus protocol is compatible with that of the standard C166 Family.

For applications which require less than 64 Kbytes of address space, a non-segmented memory model can be selected, where all locations can be addressed by 16 bits. Thus, the upper Port 2 is not needed as an output for the upper address bits (Axx ... A16), as is the case when using the segmented memory model.

The EBC also controls accesses to resources connected to the **on-chip LXBus**. The LXBus is an internal representation of the external bus and allows accessing integrated peripherals and modules in the same way as external components.

The MultiCAN module and the USIC modules are connected to and accessed via the LXBus.

<sup>1)</sup> Bus modes are switched dynamically if several address windows with different mode settings are used.

## Architectural Overview

## 2.3 On-Chip Peripheral Blocks

The XC2000 Family clearly separates peripherals from the core. This structure permits the maximum number of operations to be performed in parallel and allows peripherals to be added or deleted from family members without modifications to the core. Each functional block processes data independently and communicates information over common buses. Peripherals are controlled by data written to the respective Special Function Registers (SFRs). These SFRs are located within either the standard SFR area ( $00'FE00_H \dots 00'FFFF_H$ ), the extended ESFR area ( $00'F000_H \dots 00'F1FF_H$ ), or within the internal IO area ( $00'E000_H \dots 00'EFFF_H$ ).

These built-in peripherals either allow the CPU to interface with the external world or provide functions on-chip that otherwise would need to be added externally in the respective system.

The XC27x5X generic peripherals are:

- [Memory Checker Unit](#)
- [General Purpose Timer Unit \(GPT1, GPT2\)](#)
- [Watchdog Timer](#)
- [Capture/Compare Unit \(CAPCOM2\)](#)
- Four [Capture/Compare Units CCU6](#) (CCU60, CCU61, CCU62, CCU63)
- Two 10-bit [Analog/Digital Converters \(ADC0, ADC1\)](#)
- [Real Time Clock \(RTC\)](#)
- Thirteen/Nine [Parallel Ports](#) with a total of 119/76 I/O lines

Because the LXBus is the internal representation of the external bus, it does not support bit-addressing. Accesses are executed by the EBC as if it were external accesses. The LXBus connects on-chip peripherals to the CPU:

- [MultiCAN Module](#) with 2 CAN nodes and gateway functionality
- Two [Universal Serial Interface Channel Modules \(USIC\)](#)

Each peripheral also contains a set of Special Function Registers (SFRs) which control the functionality of the peripheral and temporarily store intermediate data results. Each peripheral has an associated set of status flags. Individually selected clock signals are generated for each peripheral from binary multiples of the master clock.

*Note: For an overview of the available peripherals for the different derivatives, please refer to “[Summary of Basic Features](#)” on Page 1-5.*

## Architectural Overview

### Peripheral Interfaces

The on-chip peripherals generally have two different types of interfaces: a bus interface to the CPU and interface signals to other on-chip peripherals or to external hardware. Communication between the CPU and peripherals is performed through Special Function Registers (SFRs) and interrupts. The SFRs serve as control/status and data registers for the peripherals. Interrupt requests are generated by the peripherals based on specific events which occur during their operation, such as operation complete, error, etc.

To interface with external hardware, specific pins of the parallel ports are used, when an input or output function has been selected for a peripheral. During this time, the port pins are controlled either by the peripheral (when used as outputs) or by the external hardware which controls the peripheral (when used as inputs). This is called the 'alternate (input or output) function' of a port pin, in contrast to its function as a general purpose I/O pin.

### Peripheral Timing

Internal operation of the CPU and peripherals is based on the system clock ( $f_{SYS}$ ). The clock generation unit uses external (e.g. a crystal) or internal clock sources to generate the system clock signal. Peripherals can be disconnected from the clock signal either temporarily to save energy or permanently if they are not used in a specific application. Peripheral SFRs may be accessed by the CPU once per state. When an SFR is written to by software in the same state where it is also to be modified by the peripheral, the software write operation has priority. Further details on peripheral timing are included in the specific sections describing each peripheral.

### Programming Hints

- **Access to SFRs:** The SFRs reside in various data pages of the memory space. The following addressing mechanisms allow access to the SFRs:
  - Indirect or direct addressing with **16-bit (mem) addresses** must guarantee that the used data page pointer (DPP0 ... DPP3) selects the corresponding data page.
  - Accesses via the Peripheral Event Controller (**PEC**) use the SRCPx and DSTPx pointers instead of the data page pointers.
  - **Short 8-bit (reg) addresses** to the standard SFR area do not use the data page pointers but directly access the registers within this 512-byte area.
  - **Short 8-bit (reg) addresses** to the extended **ESFR** area require switching to the 512-byte Extended SFR area. This is done via the EXTension instructions EXTR, EXTP(R), EXTS(R).
- **Byte Write Operations** to wordwide SFRs via indirect or direct 16-bit (mem) addressing or byte transfers via the PEC force zeros in the non-addressed byte. Byte write operations via short 8-bit (reg) addressing can access only the low byte of an SFR and force zeros in the high byte. It is therefore recommended, to use the bitfield

## Architectural Overview

instructions (BFLDL and BFLDH) to write to any number of bits in either byte of an SFR without disturbing the non-addressed byte and the unselected bits.

- **Write Operations to Write-Only Bits/Registers** usually modify bits within other registers. In some cases this modification is controlled by state machines. Therefore, the effect of the write operation may not be visible, when the modified register is read immediately after the write access that triggers the modification.
- **Reserved Bits:** Some of the bits which are contained in the XC27x5X's SFRs are marked as 'Reserved'. User software should never write '1's to reserved bits. These bits are currently not implemented and may be used in future products to invoke new functions. In that case, the active state for those new functions will be '1', and the inactive state will be '0'. Therefore writing only '0's to reserved locations allows portability of the current software to future devices. After read accesses, reserved bits should be ignored or masked out.

### Capture/Compare Unit (CAPCOM2)

The CAPCOM units support generation and control of timing sequences on up to 16 channels with a maximum resolution of 1 system clock cycle (8 cycles in staggered mode). The CAPCOM unit is typically used to handle high speed I/O tasks such as pulse and waveform generation, pulse width modulation (PMW), Digital to Analog (D/A) conversion, software timing, or time recording relative to external events.

Two 16-bit timers (T7/T8) with reload registers provide two independent time bases for each capture/compare register.

The input clock for the timers is programmable to several prescaled values of the internal system clock, or may be derived from an overflow/underflow of timer T6 in module GPT2. This provides a wide range of variation for the timer period and resolution and allows precise adjustments to the application specific requirements. In addition, external count inputs for CAPCOM timer T7 allow event scheduling for the capture/compare registers relative to external events.

The capture/compare register array contains 16 dual purpose capture/compare registers, each of which may be individually allocated to either CAPCOM timer T7 or T8 and programmed for capture or compare function.

All registers of each module have each one port pin associated with it which serves as an input pin for triggering the capture function, or as an output pin to indicate the occurrence of a compare event.

**Table 2-2 Compare Modes (CAPCOM2)**

| <b>Compare Modes</b> | <b>Function</b>                                                                                                                 |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------|
| Mode 0               | Interrupt-only compare mode;<br>several compare interrupts per timer period are possible                                        |
| Mode 1               | Pin toggles on each compare match;<br>several compare events per timer period are possible                                      |
| Mode 2               | Interrupt-only compare mode;<br>only one compare interrupt per timer period is generated                                        |
| Mode 3               | Pin set '1' on match; pin reset '0' on compare timer overflow;<br>only one compare event per timer period is generated          |
| Double Register Mode | Two registers operate on one pin;<br>pin toggles on each compare match;<br>several compare events per timer period are possible |
| Single Event Mode    | Generates single edges or pulses;<br>can be used with any compare mode                                                          |

When a capture/compare register has been selected for capture mode, the current contents of the allocated timer will be latched ('captured') into the capture/compare register in response to an external event at the port pin which is associated with this register. In addition, a specific interrupt request for this capture/compare register is generated. Either a positive, a negative, or both a positive and a negative external signal transition at the pin can be selected as the triggering event.

The contents of all registers which have been selected for one of the five compare modes are continuously compared with the contents of the allocated timers.

When a match occurs between the timer value and the value in a capture/compare register, specific actions will be taken based on the selected compare mode.

## Architectural Overview

### Capture/Compare Units CCU6

The CCU6 units support generation and control of timing sequences on up to three 16-bit capture/compare channels plus one independent 16-bit compare channel.

In compare mode, the CCU6 units provide two output signals per channel which have inverted polarity and non-overlapping pulse transitions (deadtime control). The compare channel can generate a single PWM output signal and is further used to modulate the capture/compare output signals.

In capture mode the contents of compare timer T12 is stored in the capture registers upon a signal transition at pins CCx.

The output signals can be generated in edge-aligned or center-aligned PWM mode. They are generated continuously or in single-shot mode.

Compare timers T12 and T13 are free running timers which are clocked by the prescaled system clock.

For motor control applications (brushless DC-drives) both subunits may generate versatile multichannel PWM signals which are basically either controlled by compare timer T12 or by a typical hall sensor pattern at the interrupt inputs (block commutation). The latter mode provides noise filtering for the hall inputs and supports automatic rotational speed measurement.

The trap function offers a fast emergency stop without CPU activity. Triggered by an external signal (CTRAP) the outputs are switched to selectable logic levels which can be adapted to the connected power stages.

*Note: The number of available CCU6 units and channels depends on the selected device type.*

## Architectural Overview

### General Purpose Timer Unit (GPT1, GPT2)

The GPT12E unit represents a very flexible multifunctional timer/counter structure which may be used for many different time related tasks such as event timing and counting, pulse width and duty cycle measurements, pulse generation, or pulse multiplication.

The GPT12E unit incorporates five 16-bit timers which are organized in two separate blocks, GPT1 and GPT2. Each timer in each block may operate independently in a number of different modes, or may be concatenated with another timer of the same block.

Each of the three timers T2, T3, T4 of **block GPT1** can be configured individually for one of four basic modes of operation, which are Timer, Gated Timer, Counter, and Incremental Interface Mode. In Timer Mode, the input clock for a timer is derived from the system clock, divided by a programmable prescaler, while Counter Mode allows a timer to be clocked in reference to external events.

Pulse width or duty cycle measurement is supported in Gated Timer Mode, where the operation of a timer is controlled by the 'gate' level on an external input pin. For these purposes, each timer has one associated port pin (TxIN) which serves as gate or clock input. The maximum resolution of the timers in block GPT1 is 4 system clock cycles.

The count direction (up/down) for each timer is programmable by software or may additionally be altered dynamically by an external signal on a port pin (TxEUD) to facilitate e.g. position tracking.

In Incremental Interface Mode the GPT1 timers (T2, T3, T4) can be directly connected to the incremental position sensor signals A and B via their respective inputs TxIN and TxEUD. Direction and count signals are internally derived from these two input signals, so the contents of the respective timer Tx corresponds to the sensor position. The third position sensor signal TOP0 can be connected to an interrupt input.

Timer T3 has an output toggle latch (T3OTL) which changes its state on each timer overflow/underflow. The state of this latch may be output on pin T3OUT e.g. for time out monitoring of external hardware components. It may also be used internally to clock timers T2 and T4 for measuring long time periods with high resolution.

In addition to their basic operating modes, timers T2 and T4 may be configured as reload or capture registers for timer T3. When used as capture or reload registers, timers T2 and T4 are stopped. The contents of timer T3 is captured into T2 or T4 in response to a signal at their associated input pins (TxIN). Timer T3 is reloaded with the contents of T2 or T4 triggered either by an external signal or by a selectable state transition of its toggle latch T3OTL. When both T2 and T4 are configured to alternately reload T3 on opposite state transitions of T3OTL with the low and high times of a PWM signal, this signal can be constantly generated without software intervention.

With its maximum resolution of 2 system clock cycles, the **GPT2 block** provides precise event control and time measurement. It includes two timers (T5, T6) and a capture/reload register (CAPREL). Both timers can be clocked with an input clock which is

## Architectural Overview

derived from the CPU clock via a programmable prescaler or with external signals. The count direction (up/down) for each timer is programmable by software or may additionally be altered dynamically by an external signal on a port pin (TxEUD). Concatenation of the timers is supported via the output toggle latch (T6OTL) of timer T6, which changes its state on each timer overflow/underflow.

The state of this latch may be used to clock timer T5, and/or it may be output on pin T6OUT. The overflows/underflows of timer T6 can additionally be used to clock the CAPCOM2 timers, and to cause a reload from the CAPREL register.

The CAPREL register may capture the contents of timer T5 based on an external signal transition on the corresponding port pin (CAPIN), and timer T5 may optionally be cleared after the capture procedure. This allows the XC27x5X to measure absolute time differences or to perform pulse multiplication without software overhead.

The capture trigger (timer T5 to CAPREL) may also be generated upon transitions of GPT1 timer T3's inputs T3IN and/or T3EUD. This is especially advantageous when T3 operates in Incremental Interface Mode.

---

## Architectural Overview

### Real Time Clock (RTC)

The Real Time Clock (RTC) module of the XC27x5X is directly clocked with a separate clock signal. Several internal and external clock sources can be selected via register RTCCLKCON. It is, therefore, independent from the selected clock generation mode of the XC27x5X.

The RTC basically consists of a chain of divider blocks:

- Selectable 32:1 and 8:1 dividers (on - off)
- The reloadable 16-bit timer T14
- The 32-bit RTC timer block (accessible via registers RTCH and RTCL), made of:
  - a reloadable 10-bit timer
  - a reloadable 6-bit timer
  - a reloadable 6-bit timer
  - a reloadable 10-bit timer

All timers count up. Each timer can generate an interrupt request. All requests are combined to a common node request.

*Note: The registers associated with the RTC are not affected by an application reset in order to maintain the contents even when intermediate resets are executed.*

The RTC module can be used for different purposes:

- System clock to determine the current time and date
- Cyclic time based interrupt, to provide a system time tick independent of CPU frequency and other resources
- 48-bit timer for long term measurements

## Architectural Overview

### Analog/Digital Converters (ADC0, ADC1)

For analog signal measurement, two 10-bit A/D converters (ADC0, ADC1) with 16 (or 8) multiplexed input channels including a sample and hold circuit have been integrated on-chip. They use the method of successive approximation. The sample time (for loading the capacitors) and the conversion time are programmable and can thus be adjusted to the external circuitry. The A/D converters can also operate in 8-bit conversion mode, where the conversion time is further reduced.

Several independent conversion result registers, selectable interrupt requests, and highly flexible conversion sequences provide a high degree of programmability to fulfill the requirements of the respective application. Both modules can be synchronized to allow parallel sampling of two input channels.

For applications that require more analog input channels, external analog multiplexers can be controlled automatically.

For applications that require less analog input channels, the remaining channel inputs can be used as digital input port pins.

The A/D converters of the XC27x5X support two types of request sources which can be triggered by several internal and external events.

- Scan requests are activated at the same time and then executed in a predefined sequence.
- Queued requests are executed in a user-defined sequence.

In addition, the conversion of a specific channel can be inserted into a running sequence without disturbing this sequence. All requests are arbitrated according to the priority level that has been assigned to them.

Data reduction features, such as limit checking or result accumulation, reduce the number of required CPU accesses and so allow the precise evaluation of analog inputs (high conversion rate) even at low CPU speed.

The Peripheral Event Controller (PEC) may be used to control the A/D converters or to automatically store conversion results into a table in memory for later evaluation, without requiring the overhead of entering and exiting interrupt routines for each data transfer. Therefore, each A/D converter contains 8 result registers which can be concatenated to build a result FIFO. Wait-for-read mode can be enabled for each result register to prevent loss of conversion data.

In order to decouple analog inputs from digital noise and to avoid input trigger noise those pins used for analog input can be disconnected from the digital input stages under software control. This can be selected for each pin separately via registers P5\_DDIS and P15\_DDIS (Port x Digital Input Disable).

The Auto-Power-Down feature of the A/D converters minimizes the power consumption when no conversion is in progress.

*Note: The number of available analog channels depends on the selected device type.*

## Architectural Overview

**Universal Serial Interface Channel Modules (USIC)**

Each USIC channel can be individually configured to match the application needs, e.g. the protocol can be selected or changed during run time without the need for a reset. The following protocols are supported:

- **UART** (ASC, asynchronous serial channel)
  - module capability: receiver/transmitter with max. baud rate  $f_{sys}/4$
  - application target baud rate range: 1.2 kBaud to 3.5 MBaud
  - number of data bits per data frame 1 to 63
  - MSB or LSB first
- **LIN** Support by HW (low-cost network, baud rate up to 20 kBaud)
  - data transfers based on ASC protocol
  - baud rate detection possible by built-in capture event of baud rate generator
  - checksum generation under SW control for higher flexibility
- **SSC/SPI** (synchronous serial channel with or without slave select lines)
  - module capability: slave mode with max. baud rate  $f_{sys}$
  - module capability: master mode with max. baud rate  $f_{sys} /2$
  - application target baud rate range: 2 kBaud to 10 MBaud
  - number of data bits per data frame 1 to 63, more with explicit stop condition
  - MSB or LSB first
- **IIC** (Inter-IC Bus)
  - application baud rate 100 kBaud to 400 kBaud
  - 7-bit and 10-bit addressing supported
  - full master and slave device capability
- **IIS** (infotainment audio bus)
  - module capability: receiver with max. baud rate  $f_{SYS}$
  - module capability: transmitter with max. baud rate  $f_{SYS} /2$
  - application target baud rate range: up to 26 MBaud

In addition to the flexible choice of the communication protocol, the USIC structure has been designed to reduce the system load (CPU load) allowing efficient data handling. The following aspects have been considered:

**Data buffer capability**

The standard buffer capability includes a double word buffer for receive data and a single word buffer for transmit data. This allows longer CPU reaction times (e.g. interrupt latency).

**Additional FIFO buffer capability**

In addition to the standard buffer capability, the received data and the data to be transmitted can be buffered in a FIFO buffer structure. The size of the receive and the transmit FIFO buffer can be programmed independently. Depending on the application needs, a total buffer capability of 64 data words can be assigned to the receive and transmit FIFO buffers of a USIC module (the two channels of the USIC module share the 64 data word buffer).

## Architectural Overview

In addition to the FIFO buffer, a bypass mechanism allows the introduction of high-priority data without flushing the FIFO buffer.

- **Transmit control information**

For each data word to be transmitted, a 5-bit transmit control information has been added to automatically control some transmission parameters, such as word length, frame length, or the slave select control for the SPI protocol. The transmit control information is generated automatically by analyzing the address where the user SW has written the data word to be transmitted (32 input locations =  $2^5 = 5$  bit transmit control information).

This feature allows individual handling of each data word, e.g. the transmit control information associated to the data words stored in a transmit FIFO can automatically modify the slave select outputs to select different communication targets (slave devices) without CPU load. Alternatively, it can be used to control the frame length.

- **Flexible frame length control**

The number of bits to be transferred within a data frame is independent of the data word length and can be handled in two different ways. The first option allows automatic generation of frames up to 63 bits with a known length. The second option supports longer frames (even unlimited length) or frames with a dynamically controlled length.

- **Interrupt capability**

The events of each USIC channel can be individually routed to one of 4 service request outputs, depending on the application needs. Furthermore, specific start and end of frame indications are supported in addition to protocol-specific events.

- **Flexible interface routing**

Each USIC channel offers the choice between several possible input and output pins connections for the communications signals. This allows a flexible assignment of USIC signals to pins that can be changed without resetting the device.

- **Input conditioning**

Each input signal is handled by a programmable input conditioning stage with programmable filtering and synchronization capability.

- **Baud rate generation**

Each USIC channel contains an own baud rate generator. The baud rate generation can be based either on the internal module clock or on an external frequency input. This structure allows data transfers with a frequency that can not be generated internally, e.g. to synchronize several communication partners.

- **Transfer trigger capability**

In master mode, data transfers can be triggered events generated outside the USIC module, e.g. at an input pin or a timer unit (transmit data validation). This feature allows time base related data transmission.

- **Debugger support**

The USIC offers specific addresses to read out received data without interaction with the FIFO buffer mechanism. This feature allows debugger accesses without the risk of a corrupted receive data sequence.

## Architectural Overview

To reach a desired baud rate, two criteria have to be respected, the module capability and the application environment. The module capability is defined with respect to the module's input clock frequency  $f_{sys}$ , being the base for the module operation. Although the module's capability being much higher (depending on the module clock and the number of module clock cycles needed to represent a data bit), the reachable baud rate is generally limited by the application environment. In most cases, the application environment limits the maximum reachable baud rate due to driver delays, signal propagation times, or due to EMI reasons.

*Note: Depending on the selected additional functions (such as digital filters, input synchronization stages, sample point adjustment, data structure, etc.), the maximum reachable baud rate can be limited. Please also take care about additional delays, such as (internal or external) propagation delays and driver delays (e.g. for collision detection in ASC mode, for IIC, etc.).*



Figure 2-3 USIC Channel Structure

## Architectural Overview

The USIC module contains two independent communication channels, with structure shown in [Figure 2-3](#).

The data shift unit and the data buffering of each channel support full-duplex data transfers. The protocol-specific actions are handled by protocol pre-processors (PPP). In order to simplify data handling, an additional FIFO data buffer is optionally available for each USIC module to store transmit and receive data for each channel. This FIFO data buffer is not necessarily available in all devices (please refer to USIC implementation chapter for details).

Due to the independent channel control and baud rate generation, the communication protocol, baud rate and the data format can be independently programmed for each communication channel.

## Architectural Overview

**MultiCAN Module**

The MultiCAN module contains two independently operating CAN nodes with Full-CAN functionality which are able to exchange Data and Remote Frames via a gateway function. Transmission and reception of CAN frames is handled in accordance with CAN specification V2.0 B (active). Each CAN node can receive and transmit standard frames with 11-bit identifiers as well as extended frames with 29-bit identifiers.

*Note: The number of available CAN nodes depends on the selected device type.*

All CAN nodes share a common set of 128 message objects. Each message object can be individually allocated to one of the CAN nodes. Besides serving as a storage container for incoming and outgoing frames, message objects can be combined to build gateways between the CAN nodes or to setup a FIFO buffer.

The message objects are organized in double-chained linked lists, where each CAN node has its own list of message objects. A CAN node stores frames only into message objects that are allocated to its own message object list, and it transmits only messages belonging to this message object list. A powerful, command-driven list controller performs all message object list operations.



**Figure 2-4 Block Diagram of the MultiCAN Module**

---

## Architectural Overview

### MultiCAN Features

- CAN functionality conforms to CAN specification V2.0 B active for each CAN node (compliant to ISO 11898)
- Two independent CAN nodes
- Up to 128 independent message objects (shared by the CAN nodes)
- Dedicated control registers for each CAN node
- Data transfer rate up to 1 Mbit/s, individually programmable for each node
- Flexible and powerful message transfer control and error handling capabilities
- Full-CAN functionality for message objects:
  - Can be assigned to one of the CAN nodes
  - Configurable as transmit or receive objects, or as message buffer FIFO
  - Handle 11-bit or 29-bit identifiers with programmable acceptance mask for filtering
  - Remote Monitoring Mode, and frame counter for monitoring
- Automatic Gateway Mode support
- 16 individually programmable interrupt nodes
- Analyzer mode for CAN bus monitoring

## Architectural Overview

### Watchdog Timer

The Watchdog Timer represents one of the fail-safe mechanisms which have been implemented to prevent the controller from malfunctioning for longer periods of time.

The Watchdog Timer is always enabled after a reset of the chip, and can be disabled and enabled at any time by executing instructions DISWDT and ENWDT. Thus, the chip's start-up procedure is always monitored. The software has to be designed to restart the Watchdog Timer before it overflows. If, due to hardware or software related failures, the software fails to do so, the Watchdog Timer overflows and generates a reset request.

The Watchdog Timer is a 16-bit timer, clocked with the system clock divided by 16,384 or 256. The high byte of the Watchdog Timer register can be set to a prespecified reload value (stored in WDTREL) to allow further variation of the monitored time interval. Each time it is serviced by the application software, the high byte of the Watchdog Timer is reloaded and the low byte is cleared.

Thus, time intervals between 3.2 µs and 13.4 s can be monitored (@ 80 MHz).  
The default Watchdog Timer interval after reset is 6.5 ms (@ 10 MHz).

### Memory Checker Unit

The memory checker module (MCHK) of the XC27x5X supports checking the data consistency of memories, registers (e.g. configuration registers), or communication channels. It calculates a checksum on a block of data, often called cyclic redundancy code (CRC). It is implemented as a parallel signature generation based on a multi input linear feedback shift register (MISR). Being based on a linear feedback shift register (LFSR), it also can generate pseudo-random numbers and cyclic codes.

From the programmer's point of view, the MCHK is a set of registers associated with this peripheral. To communicate respective error or operation events a port pin may be used for the signal "MATCH" to generate an external event and an interrupt line may be used for the signal "MISMATCH" to generate an internal event.

## Architectural Overview

## Parallel Ports

The XC27x5X derivatives are available in two different packages:

- In LQFP-144, they provide up to 119 I/O lines which are organized into 11 input/output ports and 2 input ports.
- In LQFP-100, they provide up to 76 I/O lines which are organized into 7 input/output ports and 2 input ports.

All port lines are bit-addressable, and all input/output lines can be individually (bit-wise) configured via port control registers. This configuration selects the direction (input/output), push/pull or open-drain operation, and activation of pull devices for each pin. Edge characteristics (shape) and driver characteristics (output current) of the port drivers can be selected for groups of 4 pins. The I/O ports are true bidirectional ports which are switched to high impedance state when configured as inputs. During the internal reset, all port pins are configured as inputs without pull devices active.

All port lines have programmable alternate input or output functions associated with them. These alternate functions can be assigned to various port pins to support the optimal utilization for a given application. For this reason, certain functions appear several times in **Table 2-3**.

All port lines that are not used for these alternate functions may be used as general purpose IO lines.

**Table 2-3 Summary of the XC27x5X's Parallel Ports**

| Port   | Width 144 <sup>1)</sup> | Width 100 <sup>1)</sup> | Alternate Functions                                                                                                                                                                                   |
|--------|-------------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port 0 | 8                       | 8                       | Address lines,<br>Serial interface lines of USIC and CAN,<br>Input/Output lines for CCU6                                                                                                              |
| Port 1 | 8                       | 8                       | Address lines,<br>Serial interface lines of USIC,<br>Input/Output lines for CCU6,<br>OCDS control, interrupts                                                                                         |
| Port 2 | 14                      | 14                      | Address and/or data lines, bus control,<br>Serial interface lines of USIC and CAN,<br>Input/Output lines for CCU6 and CAPCOM2,<br>Timer control signals,<br>DAP/JTAG, interrupts, system clock output |
| Port 3 | 8                       | ---                     | Bus arbitration signals,<br>Serial interface lines of USIC and CAN                                                                                                                                    |

**Architectural Overview**
**Table 2-3 Summary of the XC27x5X's Parallel Ports (cont'd)**

| <b>Port</b>          | <b>Width<br/>144<sup>1)</sup></b> | <b>Width<br/>100<sup>1)</sup></b> | <b>Alternate Functions</b>                                                                                                                                             |
|----------------------|-----------------------------------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port 4               | 8                                 | 4                                 | Chip select signals,<br>Serial interface lines of USIC and CAN,<br>Input/Output lines for CAPCOM2,<br>Timer control signals                                            |
| Port 5               | 16                                | 11                                | Analog input channels to ADC0,<br>Input/Output lines for CCU6,<br>Timer control signals,<br>DAP/JTAG, OCDS control, interrupts                                         |
| Port 6 <sup>2)</sup> | 4                                 | 3                                 | ADC control lines,<br>Serial interface lines of CAN,<br>Timer control signals,<br>OCDS control                                                                         |
| Port 7               | 5                                 | 5                                 | ADC control lines,<br>Serial interface lines of USIC and CAN,<br>Input/Output lines for CCU6,<br>Timer control signals,<br>DAP/JTAG, OCDS control, system clock output |
| Port 8               | 7                                 | ---                               | Serial interface lines of USIC,<br>Input/Output lines for CCU6,<br>DAP/JTAG, OCDS control                                                                              |
| Port 9               | 8                                 | ---                               | Serial interface lines of USIC and CAN,<br>Input/Output lines for CCU6,<br>DAP/JTAG, OCDS control                                                                      |
| Port 10              | 16                                | 16                                | Address and/or data lines, bus control,<br>Serial interface lines of USIC and CAN,<br>Input/Output lines for CCU6,<br>DAP/JTAG, OCDS control                           |
| Port 11              | 6                                 | ---                               | Serial interface lines of USIC and CAN,<br>Input/Output lines for CCU6                                                                                                 |
| Port 15              | 8                                 | 5                                 | Analog input channels to ADC1,<br>Timer control signals                                                                                                                |

<sup>1)</sup> These columns describe the availability of port pins in the different packages.

<sup>2)</sup> The drivers of these pins are supplied by V<sub>DDPA</sub>.

## 2.4 Clock Generation

The Clock Generation Unit uses a programmable on-chip PLL with multiple prescalers to generate the clock signals for the XC27x5X with high flexibility. The system clock  $f_{SYS}$  is the reference clock signal, which can be output to the external system. The system clock  $f_{SYS}$  can be derived from several internal and external clock sources.

The on-chip high-precision oscillator (OSC\_HP) can drive an external crystal or accepts an external clock signal. The oscillator clock frequency can be multiplied by the on-chip PLL (by a programmable factor) or can be divided by a programmable prescaler factor.

An internal clock source can provide a clock signal without requiring an external crystal.

The Oscillator Watchdog (OWD) supervises the input clock and enables an emergency clock if the input clock appears as not reliable.

## Architectural Overview

### 2.5 Power Management

The XC27x5X can operate within a wide supply voltage range from 3 V to 5 V. The internal core supply voltage is generated via on-chip Embedded Voltage Regulators and is supervised by on-chip Power Validation Circuits.

Two IO power domains help to reduce heat dissipation by supplying the major part of the device with a low voltage (3 V), while still connecting analog 5 V sensor signals to the ADCs (5 V).

The XC27x5X provides several means to control the power it consumes either at a given time or averaged over a certain timespan. Three mechanisms can be used (partly in parallel):

- **Supply Voltage Management** allows to switch off the supply voltage. This drastically reduces the power consumed because of leakage current, in particular at high temperature. A power-on reset restarts the system.
- **Clock Generation Management** controls the distribution and the frequency of internal and external clock signals. While the clock signals for currently inactive parts of logic are disabled automatically, the user can reduce the XC27x5X's CPU clock frequency which drastically reduces the consumed power.  
External circuitry can be controlled via the programmable frequency output EXTCLK.
- **Peripheral Management** permits temporary disabling of peripheral modules. Each peripheral can separately be disabled/enabled.

*Note: When selecting the supply voltage and the clock source and generation method, the required parameters must be carefully written to the respective bitfields, to avoid unintended intermediate states. Recommended sequences are provided which ensure the intended operation of power supply system and clock system.*

---

## Architectural Overview

### 2.6 On-Chip Debug Support (OCDS)

The On-Chip Debug Support system provides a broad range of debug and emulation features built into the XC27x5X. The user software running on the XC27x5X can thus be debugged within the target system environment.

The OCDS is controlled by an external debugging device via the debug interface and an optional break interface. The debugger controls the OCDS via a set of dedicated registers accessible via the debug interface. Additionally, the OCDS system can be controlled by the CPU, e.g. by a monitor program. An injection interface allows the execution of OCDS-generated instructions by the CPU.

Multiple breakpoints can be triggered by on-chip hardware, by software, or by an external trigger input. Single stepping is supported as well as the injection of arbitrary instructions and read/write access to the complete internal address space. A breakpoint trigger can be answered with a CPU-halt, a monitor call, a data transfer, or/and the activation of an external signal.

The data transferred at a watchpoint (see above) can be obtained via the debug interface or via the external bus interface for increased performance.

For the debug interface two variants can be used:

- Debug interface through the DAP port. This interface uses 2 DAP lines.
- Debug interface through the IEEE-1149-conforming JTAG port. This interface uses 4 JTAG lines.

The optional break interface uses another 2 lines.

## 2.7 Protected Bits

The XC27x5X provides a special mechanism to protect bits which can be modified by the on-chip hardware from being changed unintentionally by software accesses to related bits (see also [Section 5.8.2](#)). The following bits are protected:

**Table 2-4 XC27x5X Protected Bits**

| Register                     | Bit Name                    | Notes                                   |
|------------------------------|-----------------------------|-----------------------------------------|
| RTC_ISNC                     | T14IR,<br>CNT3IR ... CNT0IR | Interrupt node sharing request flags    |
| U0C0_0IC ...<br>U0C0_2IC     | IR                          | USIC0 channel 0 interrupt request flags |
| U0C1_0IC ...<br>U0C1_2IC     | IR                          | USIC0 channel 1 interrupt request flags |
| U1C0_0IC ...<br>U1C0_2IC     | IR                          | USIC1 channel 0 interrupt request flags |
| U1C1_0IC ...<br>U1C1_2IC     | IR                          | USIC1 channel 1 interrupt request flags |
| CAN_0IC ...<br>CAN_15IC      | IR                          | MultiCAN interrupt request flags        |
| CCU60_0IC ...<br>CCU60_3IC   | IR                          | CCU60 interrupt request flags           |
| CCU61_0IC ...<br>CCU61_3IC   | IR                          | CCU61 interrupt request flags           |
| CCU62_0IC ...<br>CCU62_3IC   | IR                          | CCU62 interrupt request flags           |
| CCU63_0IC ...<br>CCU63_3IC   | IR                          | CCU63 interrupt request flags           |
| SCU_0IC,<br>SCU_1IC          | IR                          | SCU interrupt request flags             |
| RTC_IC                       | RTCIR                       | RTC interrupt request flag              |
| EOPIC                        | EOPIR                       | End-of-PEC interrupt request flag       |
| CC2_CC16IC ...<br>CC2_CC31IC | CC16IR ... CC31IR           | CAPCOM2 interrupt request flags         |
| CC2_OUT                      | CC0IO ... CC15IO            | Compare output bits                     |
| GPT12E_T2CON                 | T2CHDIR, T2EDGE             | GPT1 timer T2 flags                     |

**Architectural Overview**
**Table 2-4 XC27x5X Protected Bits (cont'd)**

| <b>Register</b>                | <b>Bit Name</b>                                  | <b>Notes</b>                                  |
|--------------------------------|--------------------------------------------------|-----------------------------------------------|
| GPT12E_T3CON                   | T3CHDIR, T3EDGE, T3OTL                           | GPT1 timer T3 flags and output toggle latch   |
| GPT12E_T4CON                   | T4CHDIR, T4EDGE                                  | GPT1 timer T4 flags                           |
| GPT12E_T6CON                   | T6OTL                                            | GPT2 timer T6 output toggle latch             |
| GPT12E_T2IC ...<br>GPT12E_T6IC | T2IR ... T6IR                                    | GPT timer interrupt request flags             |
| GPT12E_CRIC                    | CRIR                                             | GPT2 CAPREL interrupt request flag            |
| CC2_T7IC,<br>CC2_T8IC          | T7IR, T8IR                                       | CAPCOM2 timer interrupt request flags         |
| ADC_0IC ...<br>ADC_7IC         | IR                                               | AD Converter interrupt request flags          |
| TFR                            | SR0, STKOF, STKUF, SOFTBRK                       | Class A trap flags                            |
| TFR                            | SR1, MPR, MPW, MPX, UNDOPC, ACER, PRTFLT, ILLOPA | Class B trap flags                            |
| PECISNC                        | C7IR ... C0IR                                    | All channel interrupt request flags           |
| ERU_0IC ...<br>ERU_3IC         | IR                                               | External request unit interrupt request flags |
| ----                           | IR                                               | "Unassigned node" interrupt request flags     |



## Memory Organization

### 3 Memory Organization

The memory space of the XC27x5X is configured in a “Von Neumann” architecture. This means that code and data are accessed within the same linear address space. All of the physically separated memory areas, including internal ROM and Flash, internal RAM, the internal Special Function Register Areas (SFRs and ESFRs), the internal IO area, and external memory are mapped into one common address space.



Figure 3-1 Address Space Overview

## Memory Organization

The XC27x5X provides a total addressable memory space of 16 Mbytes. This address space is arranged as 256 segments of 64 Kbytes each, and each segment is again subdivided into four data pages of 16 Kbytes each (see [Figure 3-1](#)).

Bytes are stored at even or odd byte addresses. Words are stored in ascending memory locations with the low byte at an even byte address being followed by the high byte at the next odd byte address (“little endian”). Double words (code only) are stored in ascending memory locations as two subsequent words. Single bits are always stored in the specified bit position at a word address. Bit position 0 is the least significant bit of the byte at an even byte address, and bit position 15 is the most significant bit of the byte at the next odd byte address. Bit addressing is supported for a part of the Special Function Registers, a part of the internal RAM and for the General Purpose Registers.



imb\_endianess.vsd:byte\_orga

**Figure 3-2 Storage of Words, Bytes and Bits in a Byte Organized Memory**

*Note: Byte units forming a single word or a double word must always be stored within the same physical (internal, external, ROM, RAM) and organizational (page, segment) memory area.*

## Memory Organization

### 3.1 Address Mapping

All the various memory areas and peripheral registers (see **Table 3-1**) are mapped into one contiguous address space. All sections can be accessed in the same way. The memory map of the XC27x5X contains some reserved areas, so future derivatives can be enhanced in an upward-compatible fashion.

*Note: Table 3-1 shows the maximum available memory areas. The actual available memory areas depend on the selected device type.*

**Table 3-1 XC27x5X Memory Map<sup>1)</sup>**

| Address Area                   | Start Loc.           | End Loc.             | Area Size <sup>2)</sup>  | Notes               |
|--------------------------------|----------------------|----------------------|--------------------------|---------------------|
| IMB register space             | FF'FF00 <sub>H</sub> | FF'FFFF <sub>H</sub> | 256 Bytes                |                     |
| Reserved                       | F0'0000 <sub>H</sub> | FF'FEFF <sub>H</sub> | < 1 MByte                | Minus IMB registers |
| Reserved for EPSRAM            | E8'8000 <sub>H</sub> | EF'FFFF <sub>H</sub> | 480 KBytes               | Mirrors EPSRAM      |
| Emulated PSRAM                 | E8'0000 <sub>H</sub> | E8'7FFF <sub>H</sub> | up to 32 KBytes          | With Flash timing   |
| Reserved for PSRAM             | E0'8000 <sub>H</sub> | E7'FFFF <sub>H</sub> | 480 KBytes               | Mirrors PSRAM       |
| PSRAM                          | E0'0000 <sub>H</sub> | E0'7FFF <sub>H</sub> | up to 32 KBytes          | Program SRAM        |
| Reserved for Flash             | CD'0000 <sub>H</sub> | DF'FFFF <sub>H</sub> | 1216 KBytes              |                     |
| Flash 3                        | CC'0000 <sub>H</sub> | CC'FFFF <sub>H</sub> | 64 KBytes                |                     |
| Flash 2                        | C8'0000 <sub>H</sub> | CB'FFFF <sub>H</sub> | 256 KBytes               |                     |
| Flash 1                        | C4'0000 <sub>H</sub> | C7'FFFF <sub>H</sub> | 256 KBytes               |                     |
| Flash 0                        | C0'0000 <sub>H</sub> | C3'FFFF <sub>H</sub> | 252 KBytes <sup>3)</sup> | Minus res. seg.     |
| External memory area           | 40'0000 <sub>H</sub> | BF'FFFF <sub>H</sub> | 8 MBytes                 |                     |
| External IO area <sup>4)</sup> | 21'0000 <sub>H</sub> | 3F'FFFF <sub>H</sub> | 1984 KBytes              |                     |
| Reserved                       | 20'C000 <sub>H</sub> | 20'FFFF <sub>H</sub> | 16 KBytes                |                     |
| USIC0–3 alternate regs.        | 20'B000 <sub>H</sub> | 20'BFFF <sub>H</sub> | 4 KBytes                 | Accessed via EBC    |
| MultiCAN alternate regs.       | 20'8000 <sub>H</sub> | 20'AFFF <sub>H</sub> | 12 KBytes                | Accessed via EBC    |
| Reserved                       | 20'6000 <sub>H</sub> | 20'7FFF <sub>H</sub> | 8 KBytes                 |                     |
| USIC0–3 registers              | 20'4000 <sub>H</sub> | 20'5FFF <sub>H</sub> | 8 KBytes                 | Accessed via EBC    |
| MultiCAN registers             | 20'0000 <sub>H</sub> | 20'3FFF <sub>H</sub> | 16 KBytes                | Accessed via EBC    |
| External memory area           | 01'0000 <sub>H</sub> | 1F'FFFF <sub>H</sub> | 1984 KBytes              |                     |
| SFR area                       | 00'FE00 <sub>H</sub> | 00'FFFF <sub>H</sub> | 0.5 KBytes               |                     |
| Dualport RAM (DPRAM)           | 00'F600 <sub>H</sub> | 00'FDFF <sub>H</sub> | 2 KBytes                 |                     |

## Memory Organization

**Table 3-1** XC27x5X Memory Map (cont'd)<sup>1)</sup>

| Address Area         | Start Loc.           | End Loc.             | Area Size <sup>2)</sup> | Notes |
|----------------------|----------------------|----------------------|-------------------------|-------|
| Reserved for DPRAM   | 00'F200 <sub>H</sub> | 00'F5FF <sub>H</sub> | 1 KBytes                |       |
| ESFR area            | 00'F000 <sub>H</sub> | 00'F1FF <sub>H</sub> | 0.5 KBytes              |       |
| XSFR area            | 00'E000 <sub>H</sub> | 00'EFFF <sub>H</sub> | 4 KBytes                |       |
| Data SRAM (DSRAM)    | 00'A000 <sub>H</sub> | 00'DFFF <sub>H</sub> | 16 KBytes               |       |
| Reserved for DSRAM   | 00'8000 <sub>H</sub> | 00'9FFF <sub>H</sub> | 8 KBytes                |       |
| External memory area | 00'0000 <sub>H</sub> | 00'7FFF <sub>H</sub> | 32 KBytes               |       |

<sup>1)</sup> Accesses to the shaded areas are reserved. In devices with external bus interface these accesses generate external bus accesses.

<sup>2)</sup> The areas marked with "<" are slightly smaller than indicated, see column "Notes".

3) The uppermost 4-Kbyte sector of the first Flash segment is reserved for internal use (C0'F000<sub>H</sub> to C0'FFFF<sub>H</sub>).

4) Several pipeline optimizations are not active within the external IO area. This is necessary to control external peripherals properly.

## Memory Organization

### 3.2 Register Areas

The registers controlling the system and peripheral functions of the XC27x5X can be accessed through five address areas. The address areas differ in their access properties. Please refer to [Chapter 3.6](#) and the CPU chapter for further details.

The first three areas provide Special Function Registers (SFRs) access capabilities for controlling the system and peripheral functions of the XC27x5X:

- 512-byte SFR area (located above the DPRAM: 00'FFFF<sub>H</sub> ... 00'FE00<sub>H</sub>).
- 512-byte ESFR area (located below the DPRAM: 00'F1FF<sub>H</sub> ... 00'F000<sub>H</sub>).
- 4-Kbyte XSFR area (located below the ESFR area: 00'EFFF<sub>H</sub> ... 00'E000<sub>H</sub>).

The USIC and MultiCAN registers are located within the external IO area:

- 64-Kbyte external IO area (located in: 20'0000<sub>H</sub> ... 20'FFFF<sub>H</sub>).

The IMB registers are located within a regular memory area. CPU pipeline effects must be regarded for access in this area:

- 256-byte IMB SFR area (located in: FF'FF00<sub>H</sub> ... FF'FFFF<sub>H</sub>).

This arrangement provides upward compatibility with the derivatives of the C166 and XC166 families.



**Figure 3-3 Special Function Register Mapping**

*Note: The upper 256 bytes of SFR area, ESFR area, and internal RAM are bit-addressable (see hatched blocks in [Figure 3-3](#)).*

### Special Function Registers

The functions of the CPU, the bus interface, the IO ports, and the on-chip peripherals of the XC27x5X are controlled via a number of Special Function Registers (SFRs).

All Special Function Registers can be addressed via indirect and long 16-bit addressing modes. The (word) SFRs and their respective low bytes in the SFR/ESFR areas can be addressed using an 8-bit offset together with an implicit base address. However, this **does not work** for the respective high bytes!

*Note: Writing to any byte of an SFR causes the not addressed complementary byte to be cleared.*

The upper half of the SFR-area (00'FFFF<sub>H</sub> ... 00'FF00<sub>H</sub>) and the ESFR-area (00'F1FF<sub>H</sub> ... 00'F100<sub>H</sub>) is bit-addressable, so the respective control/status bits can be modified directly or checked using bit addressing.

## Memory Organization

When accessing registers in the ESFR area using 8-bit addresses or direct bit addressing, an Extend Register (EXTR) instruction is required beforehand to switch the short addressing mechanism from the standard SFR area to the Extended SFR area. This is not required for 16-bit and indirect addresses. The GPRs R15 ... R0 are duplicated, i.e. they are accessible within both register blocks via short 2-, 4-, or 8-bit addresses without switching.

### ESFR\_SWITCH\_EXAMPLE:

```
EXTR #4          ;Switch to ESFR area for next 4 instr.  
MOV STMREL, #data16 ;STMREL uses 8-bit reg addressing  
BFLDL STMCON, #mask, #data8 ;Bit addressing for bitfields  
BSET WUCR.CLRTRG      ;Bit addressing for single bits  
MOV T8REL, R1        ;T8REL uses 16-bit mem address,  
                     ;R1 is duplicated into the ESFR space  
                     ;(EXTR is not required for this access)  
;---- ;----- ;The scope of the EXTR #4 instruction ...  
                     ;... ends here!  
MOV T8REL, R1        ;T8REL uses 16-bit mem address,  
                     ;R1 is accessed via the SFR space
```

In order to minimize the use of the EXTR instructions the ESFR area mostly holds registers which are mainly required for initialization and mode selection. Registers that need to be accessed frequently are allocated to the standard SFR area, wherever possible.

*Note: The tools are equipped to monitor accesses to the ESFR area and will automatically insert EXTR instructions, or issue a warning in case of missing or excessive EXTR instructions.*

Accesses to registers in the XSFR area use 16-bit addresses and require no specific addressing modes or precautions.

## General Purpose Registers

The General Purpose Registers (GPRs) use a block of 16 consecutive words either within the global register bank or within one of the two local register banks. The bit-field BANK in register PSW selects the currently active register bank. The global register bank is mirrored to a section in the DPRAM, the Context Pointer (CP) register determines the base address of the currently active global register bank section. This register bank may consist of up to 16 Word-GPRs (R0, R1, ... R15) and/or of up to 16 byte-GPRs (RL0,RH0, ... RL7, RH7). The sixteen byte-GPRs are mapped onto the first eight Word GPRs (see [Table 3-2](#)).

In contrast to the system stack, a register bank grows from lower towards higher address locations and occupies a maximum space of 32 bytes. The GPRs are accessed via short 2-, 4-, or 8-bit addressing modes using the Context Pointer (CP) register as base

## Memory Organization

address for the global bank (independent of the current DPP register contents). Additionally, each bit in the currently active register bank can be accessed individually.

**Table 3-2 Mapping of General Purpose Registers to DPRAM Addresses**

| DPRAM Address          | High Byte Registers | Low Byte Registers | Word Registers |
|------------------------|---------------------|--------------------|----------------|
| <CP> + 1E <sub>H</sub> | –                   | –                  | R15            |
| <CP> + 1C <sub>H</sub> | –                   | –                  | R14            |
| <CP> + 1A <sub>H</sub> | –                   | –                  | R13            |
| <CP> + 18 <sub>H</sub> | –                   | –                  | R12            |
| <CP> + 16 <sub>H</sub> | –                   | –                  | R11            |
| <CP> + 14 <sub>H</sub> | –                   | –                  | R10            |
| <CP> + 12 <sub>H</sub> | –                   | –                  | R9             |
| <CP> + 10 <sub>H</sub> | –                   | –                  | R8             |
| <CP> + 0E <sub>H</sub> | RH7                 | RL7                | R7             |
| <CP> + 0C <sub>H</sub> | RH6                 | RL6                | R6             |
| <CP> + 0A <sub>H</sub> | RH5                 | RL5                | R5             |
| <CP> + 08 <sub>H</sub> | RH4                 | RL4                | R4             |
| <CP> + 06 <sub>H</sub> | RH3                 | RL3                | R3             |
| <CP> + 04 <sub>H</sub> | RH2                 | RL2                | R2             |
| <CP> + 02 <sub>H</sub> | RH1                 | RL1                | R1             |
| <CP> + 00 <sub>H</sub> | RH0                 | RL0                | R0             |

The XC27x5X supports fast register bank (context) switching. Multiple global register banks can physically exist within the DPRAM at the same time. Only the global register bank selected by the Context Pointer register (CP) is active at a given time, however. Selecting a new active global register bank is simply done by updating the CP register. A particular Switch Context (SCXT) instruction performs register bank switching by automatically saving the previous context and loading the new context. The number of implemented register banks (arbitrary sizes) is limited only by the size of the available DPRAM.

*Note: The local GPR banks are not memory mapped and the GPRs cannot be accessed using a long or indirect memory address.*

## PEC Source and Destination Pointers

The source and destination address pointers for data transfers on the PEC channels are located in the XSFR area.

## Memory Organization

Each channel uses a pair of pointers stored in two subsequent word locations with the source pointer (SRCP $x$ ) on the lower and the destination pointer (DSTP $x$ ) on the higher word address ( $x = 7 \dots 0$ ). An additional segment register stores the associated source and destination segments, so PEC transfers can move data from/to any location within the complete addressing range.

Whenever a PEC data transfer is performed, the pair of source and destination pointers (selected by the specified PEC channel number) accesses the locations referred to by these pointers independently of the current DPP register contents.

If a PEC channel is not used, the corresponding pointer locations can be used for other purposes.

*Note: Writing to any byte of the PEC pointers causes the not addressed complementary byte to be cleared.*

## Memory Organization

### 3.3 Data Memory Areas

The XC27x5X provides two on-chip RAM areas exclusively for data storage:

- The **Dual Port RAM (DPRAM)** can be used for global register banks (GPRs), system stack, storage of variables and other data, in particular for MAC operands.
- The **Data SRAM (DSRAM)** can be used for system stack (recommended), storage of variables and other data.

*Note: Data can also be stored in the PSRAM (see [Section 3.10](#)). However, both data memory areas provide the fastest access.*

Depending on the device additional on-chip memory areas may exist with the special purpose to retain data while the system power domain is switched off. The XC27x5X contains:

- The **Marker Memory (MKMEM)**.

#### Dual-Port RAM (DPRAM)

The XC27x5X provides 2 Kbytes of DPRAM ( $00'F600_H \dots 00'FDFF_H$ ). Any word or byte data in the DPRAM can be accessed via indirect or long 16-bit addressing modes, if the selected DPP register points to data page 3. Any word data access is made on an even byte address.

For PEC data transfers, the DPRAM can be accessed independent of the contents of the DPP registers via the PEC source and destination pointers.

The upper 256 bytes of the DPRAM ( $00'FD00_H$  through  $00'FDFF_H$ ) are provided for single bit storage, and thus they are bit addressable.

*Note: Code cannot be executed out of the DPRAM.*

*Note: The locations  $00'FBFE_H \dots 00'FC01_H$  of the DPRAM may be altered during the initialization phase after a reset. This area, therefore, should not store data to be preserved beyond a reset.*

An area of 3 Kbytes is dedicated to DPRAM ( $00'F200_H \dots 00'FDFF_H$ ). The locations without implemented DPRAM are reserved.

#### Data SRAM (DSRAM)

The XC27x5X provides 16 Kbytes of DSRAM ( $00'A000_H \dots 00'DFFF_H$ ). Any word or byte data in the DSRAM can be accessed via indirect or long 16-bit addressing modes, if the selected DPP register points to data page 3 (for the range  $00'C000_H \dots 00'DFFF_H$ ) or to data page 2 (for the range  $00'A000_H \dots 00'BFFF_H$ ). Any word data access is made on an even byte address.

For PEC data transfers, the DSRAM can be accessed independent of the contents of the DPP registers via the PEC source and destination pointers.

*Note: Code cannot be executed out of the DSRAM.*

## Memory Organization

An area of 24 Kbytes is dedicated to DSRAM ( $00'8000_H \dots 00'DFFF_H$ ). The locations without implemented DSRAM are reserved.

### Marker Memory (MKMEM)

The MKMEM provides 4 bytes of memory. It can be used to store system state information during power down.

The MKMEM consists of 2 16-bit SFRs that are accessible as all other SFRs. Details are described in the SCU chapter.

*Note: Code cannot be executed out of the MKMEM.*

## Memory Organization

### 3.4 Program Memory Areas

The XC27x5X provides two on-chip program memory areas for code/data storage:

- The **Program Flash/ROM** stores code and constant data. Flash memory is (re-) programmed by the application software or flash loaders, ROM is mask-programmed in the factory.
- The **Program SRAM (PSRAM)** stores temporary code sequences and other data. For example higher level boot loader software can be written to the PSRAM and then be executed to program the on-chip Flash memory.



Figure 3-4 On-Chip Program Memory Mapping

## Memory Organization

### 3.4.1 Program/Data SRAM (PSRAM)

The XC27x5X provides up to 32 Kbytes of PSRAM ( $E0'0000_H \dots E0'7FFF_H$ ). The PSRAM provides fast code execution without initial delays. Therefore, it supports non-sequential code execution, for example via the interrupt vector table.

Any word or byte data in the PSRAM can be accessed via indirect or long 16-bit addressing modes, if the selected DPP register points to one of its data pages. Any word data access is made on an even byte address.

For PEC data transfers, the PSRAM can be accessed independent of the contents of the DPP registers via the PEC source and destination pointers.

Any data can be stored in the PSRAM. Because the PSRAM is optimized for code fetches, however, data accesses to the data memories provide higher performance.

*Note: The PSRAM is not bit-addressable.*

*Note: The upper 256 Bytes of the PSRAM may be altered during the initialization phase after a reset. This area, therefore, should not store data to be preserved beyond a reset.*

*Also, during bootstrap loader operation, the serially received data is stored in the PSRAM starting at location  $E0'0000_H$ .*

An area of 512 Kbytes is dedicated to PSRAM ( $E0'0000_H \dots F7'FFFF_H$ ). The locations without implemented PSRAM are reserved.

## Flash Emulation

During code development the PSRAM will often be used for storing code or data that the production chip will later contain in the flash memory. In order to ensure similar execution time the PSRAM supports a second access path in the range  $E8'0000_H \dots EF'FFFF_H$  with timing parameters that correspond to Flash timing. The number of wait-cycles is determined by the flash access timing configuration (see [IMB\\_IMBCTRL.WSFLASH](#)). Writes are always performed without wait-cycles.

This flash access timing imitation is nearly cycle accurate because the same read logic as for reading the flash memory is used<sup>1)</sup>. Discrepancies might occur if the software uses the PSRAM for flash emulation and directly as PSRAM. During emulation access conflicts can cause a slightly different timing as in the product chip where these conflicts do not occur.

Another source of timing differences can be access conflicts at the flash modules in the product chip. Data reads and instruction fetches that target different flash modules can be executed concurrently whereas if they target the same flash module they are

<sup>1)</sup> The dual use of the flash read logic might cause unexpected behavior: while the IMB Core is busy with updating the protection configuration (after startup or after changing the security pages) read accesses to the flash emulation range of the PSRAM are blocked because Flash data reads would be blocked also.

## Memory Organization

executed sequentially with the data access as first. In the flash emulation this type of conflict can not occur. The data and the instruction access will both incur the defined number of wait-cycles (as if they would target different flash modules) and if they collide at the PSRAM interface the instruction fetch will see an additional wait-cycle.

### Data Integrity

The PSRAM contains its own error control which can be switched between ECC and parity. Details are described in the SCU chapter.

### Write Protection

As the PSRAM is often used to store timing critical code or constant data it is supplied with a write protection. After storing critical data in the PSRAM the register field **IMB\_IMBCTRH.PSPROT** can be used to split the PSRAM into a read-only and a writable part. Write accesses to the read-only part are blocked and a trap can be activated.

### 3.4.2 Non-Volatile Program Memory (Flash)

The XC27x5X provides up to up to 828 Kbytes of program Flash starting at address C0'0000<sub>H</sub>. Code and data fetches are always 64-bit aligned, using byte select lines for word and byte data.

Any word or byte data in the program memory can be accessed via indirect or long 16-bit addressing modes, if the selected DPP register points to one of the respective data pages. Any word data access is made on an even byte address.

For PEC data transfers, the program memory can be accessed independent of the contents of the DPP registers via the PEC source and destination pointers.

*Note: The program memory is not bit-addressable.*

An area of 2 Mbytes is dedicated to program memory (C0'0000<sub>H</sub> ... DF'FFFF<sub>H</sub>). The locations without implemented program memory are reserved.

A more detailed description can be found in “[Embedded Flash Memory](#)” on [Page 3-19](#).

## Memory Organization

### 3.5 System Stack

The system stack may be defined anywhere within the XC27x5X's memory areas (including external memory).

For all system stack operations the respective stack memory is accessed via a 24-bit stack pointer. The Stack Pointer (SP) register provides the lower 16 bits of the stack pointer (stack pointer offset), the Stack Pointer Segment (SPSEG) register adds the upper 8 bits of the stack pointer (stack segment). The system stack grows downward from higher towards lower locations as it is filled. Only word accesses are supported to the system stack.

Register SP is decremented before data is pushed on the system stack, and incremented after data has been pulled from the system stack. Only word accesses are supported to the system stack.

By using register SP for stack operations, the size of the system stack is limited to 64 KBytes. The stack must be located in the segment defined by register SPSEG.

The stack pointer points to the latest system stack entry, rather than to the next available system stack address.

A stack overflow (STKOV) register and a stack underflow (STKUN) register are provided to control the lower and upper limits of the selected stack area. These two stack boundary registers can be used both for protection against data corruption.

For best performance it is recommended to locate the stack to the DPRAM or to the DSRAM. Using the DPRAM may conflict with register banks or MAC operands.

## Memory Organization

### 3.6 IO Areas

The following areas of the XC27x5X's address space are marked as IO area:

- The **external IO area** is provided for external peripherals (or memories) and also comprises the on-chip LXBus-peripherals, such as the MultiCAN or USIC modules. It is located from  $20'0000_H$  to  $3F'FFFF_H$  (2 Mbytes).
- The **internal IO area** provides access to the internal peripherals and is split into three blocks:
  - The SFR area, located from  $00'FE00_H$  to  $00'FFFF_H$  (512 bytes).
  - The ESFR area, located from  $00'F000_H$  to  $00'F1FF_H$  (512 bytes).
  - The XSFR area, located from  $00'E000_H$  to  $00'EFFF_H$  (4 Kbytes).

*Note: The external IO area supports real byte accesses. The internal IO area does not support real byte transfers, the complementary byte is cleared when writing to a byte location.*

The IO areas have special properties, because peripheral modules must be controlled in a different way than memories:

- Accesses are not buffered and cached, the write back buffers and caches are not used to store IO read and write accesses.
- Speculative reads are not executed, but delayed until all speculations are solved (e.g. pre-fetching after conditional branches).
- Data forwarding is disabled, an IO read access is delayed until all IO writes pending in the pipeline are executed, because peripherals can change their internal state after a write access.

## Memory Organization

### 3.7 External Memory Space

The XC27x5X is capable of using an address space of up to 16 Mbytes. Only parts of this address space are occupied by internal memory areas or are reserved. A total area of approximately 12 Mbytes references external memory locations. This external memory is accessed via the XC27x5X's external bus interface.

**Selectable memory bank sizes** are supported: The maximum size of a bank in the external memory space depends on the number of activated address bits. It can vary from 64 Kbytes (with A15 ... A0 activated) to 12 Mbytes (with A23 ... A0 activated). The logical size of a memory bank and its location in the address space is defined by programming the respective address window. It can vary from 4 Kbytes to 12 Mbytes.

Each bank can be directly addressed via the address bus, while the programmable chip select signals can be used to select various memory banks.

The XC27x5X also supports **four different bus types**:

- Multiplexed 16-bit Bus (default after Reset).
- Multiplexed 8-bit Bus.
- Demultiplexed 16-bit Bus.
- Demultiplexed 8-bit Bus.

For further details about the external bus configuration and control refer to the External Bus Controller chapter.

External word and byte data can only be accessed via indirect or long 16-bit addressing modes using one of the four DPP registers. There is no short addressing mode for external operands. Any word data access is made to an even byte address.

For PEC data transfers the external memory can be accessed independent of the contents of the DPP registers via the PEC source and destination pointers.

*Note: The external memory is not bit addressable.*

### 3.8 Crossing Memory Boundaries

The address space of the XC27x5X is implicitly divided into equally sized blocks of different granularity and into logical memory areas. Crossing the boundaries between these blocks (code or data) or areas requires special attention to ensure that the controller executes the desired operations.

**Memory Areas** are partitions of the address space assigned to different kinds of memory (if provided at all). These memory areas are the SFR areas, the on-chip program or data RAM areas, the on-chip ROM/Flash (if available), the on-chip LXBus-peripherals (if integrated), and the external memory.

Accessing subsequent data locations which belong to different memory areas is no problem. However, when executing code, the different memory areas must be switched explicitly via branch instructions. Sequential boundary crossing is not supported and leads to erroneous results.

## Memory Organization

*Note: Changing from the external memory area to the on-chip RAM area takes place within segment 0.*

**Segments** are contiguous blocks of 64 Kbytes each. They are referenced via the Code Segment Pointer CSP for code fetches and via an explicit segment number for data accesses overriding the standard DPP scheme.

During code fetching, segments are not changed automatically, but rather must be switched explicitly. The instructions JMPS, CALLS and RETS will do this.

**Data Pages** are contiguous blocks of 16 Kbytes each. They are referenced via the data page pointers DPP3 ... DPP0 and via an explicit data page number for data accesses overriding the standard DPP scheme. Each DPP register can select one of the possible 1024 data pages. The DPP register which is used for the current access is selected via the two upper bits of the 16-bit data address. Therefore, subsequent 16-bit data addresses which cross the 16-Kbytes data page boundaries will use different data page pointers, while the physical locations need not be subsequent within memory.

### 3.9 Embedded Flash Memory

This chapter describes the embedded flash memory of the XC27x5X:

- [Section 3.9.1](#) defines the flash specific nomenclature and the structure of the flash memory.
- [Section 3.9.2](#) describes the operating modes.
- [Section 3.9.3](#) contains all operations.
- [Section 3.9.4](#) gives the details of operating sequences.
- The three sections [Section 3.9.7](#), [Section 3.9.8](#) and [Section 3.9.9](#) look more into depth of maintaining data integrity and protection issues.
- [Section 3.9.10](#) discusses Flash EEPROM emulation.
- [Section 3.9.11](#) describes interrupt generation by the flash memory.

The [Chapter 3.10](#) describes how the flash memory is embedded into the memory architecture of the XC27x5X and lists all SFRs that affect its behavior.

#### 3.9.1 Definitions

This section defines the nomenclature and some abbreviations as a base for the rest of the document. The used flash memory is a non-volatile memory (“NVM”) based on a floating gate one-transistor cell. It is called “non-volatile” because the memory content is kept when the memory power supply is shut off.

#### Logical and Physical States

Flash memory content can not be changed directly as in SRAMs. Changing data is a complicated process with a typically much longer duration than reading.

- **Erasing:** The erased state of a cell is logical 0. Forcing an flash cell to this state is called “erasing”. Erasing is possible with a minimum granularity of one page (see below). A device is delivered with completely erased flash memory.
- **Programming:** The programmed state of a cell is logical 1. Changing an erased cell to this state is called “programming”. A page must only be programmed once and has to be erased before it can be programmed again.

The above listed processes have certain limitations:

- **Retention:** This is the time during which the data of a flash cell can be read reliably. The retention time is a statistical figure that depends on the operating conditions of the flash array (temperature profile) and the accesses to the flash array. With an increasing number of program/erase cycles (see endurance) the retention is lowered. Drain and gate disturbs decrease data retention as well.
- **Endurance:** As described above the data retention is reduced with an increasing number of program/erase cycles. A flash cell incurs one cycle whenever its page or sector is erased. This number is called “endurance”. As said for the retention it is a statistical figure that depends on operating conditions and the use of the flash cells and not to forget on the required quality level.

## Memory Organization

- **Drain Disturb:** Because of using a so called “one-transistor” flash cell each program access disturbs all pages of the same sector slightly. Over long these “drain disturbs” make 0 and 1 values indistinguishable and thus provoke read errors. This effect is again interrelated with the retention. A cell that incurred a high number of drain disturbs will have a lower retention. The physical sectors of the flash array are isolated from each other. So pages of a different sector do not incur a drain disturb. This effect must be therefore considered when the page erase feature is used.

The durations of programming and erasing as well as the limits for endurance, retention and drain disturbs are documented in the data sheet.

**Attention:** *No means exist in the device that prevent the application from violating these limitation.*

### Array Structure

The flash memory is hierarchically structured:

- **Block:** A block consists of 128 user data bits (i.e. 16 bytes) and 9 ECC bits. One read access delivers one block.
- **Page:** A page consists of 8 blocks (i.e. 128 bytes). Programming changes always complete pages.
- **Sector:** A sector consists of 32 pages (i.e. 4096 bytes). The pages of one sector are affected by drain disturb as described above. The pages of different sectors are isolated from each other.
- **Array:** Each 256 KB array has 64 sectors<sup>1)</sup> and the 64 KB array has 16 sectors. Usually when referring to an “array” this contains as well all accompanying logic as assembly buffer, high voltage logic and the digital logic that allows to operate them in parallel.
- **Memory:** The complete flash memory of the XC27x5X consists of 4 flash arrays.

This structure of the 256 KB array is visualized in [Figure 3-5](#). The structure of the 64 KB array is analog.

<sup>1)</sup> In the Flash0 one sector is reserved for device internal purposes. It is not accessible by software.



**Figure 3-5 Flash Structure**

### 3.9.2 Operating Modes

The IMB and the flash memory and each flash module have certain modes of operation. Some modes define clocking and power supply and the operating state of the analog logic as oscillators and voltage pumps. Overall system modes (e.g. startup mode) influence the behavior of the flash memory as well.

Other modes define the functional behavior. These will be discussed here.

#### 3.9.2.1 Standard Read Mode

After reset and after performing a clean startup the flash memory with all its modules is in “standard read mode”. In this mode it behaves as an on-chip ROM. This mode is entered:

- After reset when the complete start-up has been performed.
- After completion of a longer lasting command like “erase” or “program” which is acknowledged by clearing the “busy” flag.
- Immediately after each other command execution.

## Memory Organization

- In case of detecting an execution error like attempting to write to a write protected range, sending a wrong password, after all sequence errors.

For the long lasting commands the read mode stays active until the last command of the sequence is received and the operation is started.

### 3.9.2.2 Command Mode

After receiving the last command of a command sequence the addressed flash module (not the whole flash memory!) is placed into command mode. For most commands this will not be noticed by the user as the command executes immediately and afterwards the flash module is placed again into read mode. For the long lasting commands the flash module stays in command mode for several milliseconds. This is reported by setting the corresponding “busy” flag. The data of a busy flash module cannot be read but other not busy flash modules stay readable. New command sequences are generally not accepted and cause a sequence error until the running operation has finished. In certain cases however new command sequences are accepted in order to enable concurrent programming and erase of independent flash modules.

Read accesses to busy flash modules stall the CPU until the read mode is entered again. A stalled CPU responds only to the reset. As no interrupts can be handled this state must be avoided. Nevertheless this feature can be used to execute code from a flash module that erases or programs data in the same flash module.

*Note: Because command sequences to busy flash memory are not always rejected by the hardware with a sequence error it is necessary to handle all commands more careful than in previous device generations that didn't support concurrent processes. A new command sequence shall be only be issued to a flash module after checking that it is not busy anymore. This is especially vital when using the “stall CPU when reading busy flash” feature. Further advice can be found in [Section 3.9.5](#) (sequence errors) and [Section 3.9.6](#) (concurrent processes).*

### 3.9.2.3 Page Mode

The page mode is entered with the “[Enter Page Mode](#)” command. Please find its description below. A flash module that is in page mode can still be read (so it is concurrently in “read mode”). At a time only one flash module can be in page mode.

When the flash memory is in page mode — i.e. one of the flash modules is in page mode — some command sequences are not allowed. These are all erase sequences and the “change read margin” sequence. These are ignored and a sequence error is reported.

## Memory Organization

### 3.9.3 Operations

The flash memory supports the following operations:

- Instruction fetch.
- Data read.
- Command sequences to change data and control the protection.

#### 3.9.3.1 Instruction Fetch from Flash Memory

Instructions are fetched by the PMU in groups of aligned 64 bits. These code requests are forwarded to the flash memory. It needs a varying number of cycles (depending on the system clock frequency) to perform the read access. The number of cycles must be known to the IMB Core because the flash does not signal data availability. The number of wait states is therefore stored in the **IMB\_IMBCTRL** register.

The complete duration of a flash read access is: **IMB\_IMBCTRL.WSFLASH** + 1 cycles. Consult the data sheet for correct values of WSFLASH dependent on the system clock frequency and device.

One read access to the flash memory delivers 128 data bits and a 9-bit ECC value. The ECC value is used to detect and possibly correct errors. The addressed 64-bit part of the 128-bit chunk is sent to the PMU. The complete 128 data bits and the 9 ECC bits are stored in the IMB Core with their address. If a succeeding fetch request matches this address the data is delivered from the buffer without performing a read access in the flash memory. The delivery from the buffer happens after one cycle. The flash read wait-cycles are not waited.

The stored data are a kind of instruction cache. In order to support self-modifying code (e.g. boot loaders) this cache is invalidated when the corresponding address is written (i.e. erased or programmed).

In addition to this fetch buffer the IMB Core has an additional performance increasing feature — the Linear Code Pre-Fetch. When this feature is enabled with **IMB\_IMBCTRL.DLCPF** = 0 the IMB Core fetches autonomously the following instructions while the CPU executes from its own buffers or the fetch buffer. As this feature is fetching only the linear successors (it does not analyze the code stream) it is most effective for code with longer linear sequences. For code with a high density of jumps and calls it can even cause a reduction of performance and should be switched off.

## Memory Organization

### 3.9.3.2 Data Reads from Flash Memory

Data reads are issued by the DMU. Data is always requested in 16-bit words. The flash memory delivers for every read request 128 bits plus ECC as described in “[Instruction Fetch from Flash Memory” on Page 3-23](#).

The IMB Core has to get all 128 bits to evaluate the ECC data. The requested 16 bits will be delivered to the DMU. All data and ECC bits are kept in the data register and their address is kept in the address register. For all following data reads the address is compared with the address register and in case of a match the data is delivered after one cycle from the data register. Every data read that is not delivered from this cache invalidates the cache content. When the requested data arrives the cache contains again valid data.

This small data cache is invalidated when a write (i.e. erase or program) access to this address happens.

For data reads the IMB Core does not perform any autonomous pre-fetching.

### 3.9.3.3 Data Writes to Flash Memory

Flash memory content can not be changed by directly writing data to this memory. Command sequences are used to execute all other operations in the flash except reading. Command sequences consist of data writes with certain data to the flash memory address range. All data moves targeting this range are interpreted as command sequences. If they do not match a defined one or if the IMB Core cannot accept a new one because it is busy a sequence error is reported.

## Memory Organization

### 3.9.3.4 Command Sequences

As described before changing data in the flash memory is performed with command sequences.

**Table 3-3 Command Sequence Overview**

| Command Sequence                                | Description                                         | Details on Page           |
|-------------------------------------------------|-----------------------------------------------------|---------------------------|
| <a href="#">Reset to Read</a>                   | Reset Flash into read mode and clear error flags.   | <a href="#">Page 3-27</a> |
| <a href="#">Clear Status</a>                    | Clear error and status flags.                       | <a href="#">Page 3-27</a> |
| <a href="#">Change Read Margin</a>              | Change read margins.                                | <a href="#">Page 3-27</a> |
| <a href="#">Enter Page Mode</a>                 | Prepare page for programming.                       | <a href="#">Page 3-28</a> |
| <a href="#">Enter Security Page Mode</a>        | Prepare security page for programming.              | <a href="#">Page 3-29</a> |
| <a href="#">Load Page Word</a>                  | Load page with data.                                | <a href="#">Page 3-30</a> |
| <a href="#">Program Page</a>                    | Start page programming process.                     | <a href="#">Page 3-31</a> |
| <a href="#">Erase Sector</a>                    | Start sector erase process.                         | <a href="#">Page 3-32</a> |
| <a href="#">Erase Page</a>                      | Start page erase process.                           | <a href="#">Page 3-33</a> |
| <a href="#">Erase Security Page</a>             | Start security page erase process.                  | <a href="#">Page 3-33</a> |
| <a href="#">Disable Read Protection</a>         | Disable temporarily read protection with password.  | <a href="#">Page 3-34</a> |
| <a href="#">Disable Write Protection</a>        | Disable temporarily write protection with password. | <a href="#">Page 3-35</a> |
| <a href="#">Re-Enable Read/Write Protection</a> | Re-enable protection.                               | <a href="#">Page 3-36</a> |

## Memory Organization

### 3.9.4 Details of Command Sequences

The description defines the command sequence with pseudo assembler code. It is “pseudo” because all addresses are direct addresses which is generally not possible in real assembler code.

The commands are called by a sequence of one to six data moves into the flash memory range. The data moves must be of the “word” type, i.e. not byte move instructions. The following sections describe each command. The following abbreviations for addresses and data will be used:

- PA: “Page Address”. This is the base address of the destination page. For example the very first page has the address  $C0'0000_H$ . The page 13 of the second array has the  $PA = C0'0000_H + 1 \cdot 256 \cdot 1024$  (for the array) +  $0 \cdot 4 \cdot 1024$  (for the sector) +  $13 \cdot 128$  (for the page) =  $C4'0680_H$ .
- SECPA: “Security Page Address”. This is the virtual address of a security page. It is “virtual” because SECPA is just used as argument of the command sequence to identify the security page but the physical storage of the security page is hidden.

Two security pages are defined:

SecP0: address  $C0'0000_H$ .

SecP1: address  $C0'0080_H$ .

- WD: “Write Data”. This is a 16-bit data word that is written into the assembly buffer.
- SA: “Sector Address”. This is the physical sector number as defined in **Figure 3-6** based on the address of the flash module. Two examples as clarification:
  1. Physical sector number 16 of the first array that is based on  $C0'0000_H$  is addressed with  $SA = C0'0000_H + 16 \cdot 4 \cdot 1024 = C1'0000_H$ .
  2. The second 256 KB array has the base address  $C4'0000_H$  (as shown in **Table 3-1**). So its physical sector number 3 has the  $SA = C4'0000_H + 3 \cdot 4 \cdot 1024 = C4'3000_H$ .
- PWD: “Password”. This is a 64-bit password. It is transferred in 4 16-bit data words  $PWD0 = PWD[15:0]$ ,  $PWD1 = PWD[31:16]$ ,  $PWD2 = PWD[47:32]$  and  $PWD3 = PWD[63:48]$ .
- Address XX followed by two hexadecimal digits, for example “XXAA<sub>H</sub>”. If the command targets a certain flash module the XX must be translated to its base address. So “XXAA<sub>H</sub>” means  $C0'00AA_H$  for all commands addressing flash 0,  $C4'00AA_H$  for flash 1 and  $C8'00AA_H$  for flash 2. If a command (e.g. “Clear Status”) addresses the complete flash memory the base address of flash module 0 must be used.
- Data XX followed by two hexadecimal digits, e.g. XXA5<sub>H</sub>. This is a “don’t care” data word where only the low byte must match a certain pattern. So in this example all data words like 12A5<sub>H</sub> or 79A5<sub>H</sub> can be used.
- MR: “Margin”. This 8-bit number defines the read margin. MR can take the values 00<sub>H</sub> (normal read), 01<sub>H</sub> (hard read 0), 02<sub>H</sub> (alternate hard read 0), 05<sub>H</sub> (hard read 1), 06<sub>H</sub> (alternate hard read 1). All other values of MR are reserved.

## Memory Organization

### Reset to Read

*Arguments:* –

*Definition:*

```
MOV XXAAH, XXF0H
```

*Timing:* One cycle command that does not set any “BUSY” flags. But note that an immediately following write access to the IMB Core is stalled for a few clock cycles during which the IMB Core is busy with aborting a previous command.

*Description:* The internal command state machine is reset to initial state and returns to read mode. An already started programming or erase operation is not affected and will be continued (the “Reset to Read” command — i.e. all commands — will anyhow not be accepted while the IMB Core is busy).

The “Reset to Read” command is a single cycle command. It can be used during a command sequence to reset the command interpreter and return the IMB Core into its initial state. It clears also all error flags in the Flash Status Register IMB\_FSR and an active page mode is aborted. “Reset to Read” can not be used to abort an active command mode. When at least one flash module is busy this command is rejected with SQER<sup>1)</sup>.

This command clears: PROER, PAGE, SQER, OPER, ISBER, IDBER, DSBER, DDBER.

### Clear Status

*Arguments:* –

*Definition:*

```
MOV XXAAH, XXF5H
```

*Timing:* 1-cycle command that does not set any busy flags.

*Description:* The flags OPER, SQER, PROER, ISBER, IDBER, DSBER, DDBER in Flash status register are cleared. Additionally, the process status bits (PROG, ERASE, POWER, MAR) are cleared.

This command must not be issued when any of the flash modules is in command mode. In this case it is ignored and a sequence error is reported.

### Change Read Margin

*Arguments:* MR

<sup>1)</sup> In the XC27x5X there is one exception to this rule: when one flash module is busy with program or erase and the FAPI has received some but not all command cycles of a concurrently executable command sequence (“Erase Sector”, “Erase Page”, “Enter Page Mode”, “Load Page Word”, “Program Page”) then a Reset to Read is performed without issuing a sequence error.

## Memory Organization

### Definition:

```
MOV XXAAH, XXB0H
MOV XX54H, XXMRH
```

*Timing:* 2-cycle command that sets “BUSY” of the addressed flash module for around 30 micro seconds.

*Description:* This command sequence changes the read margin of one flash module. The address XX of the second move identifies the targeted flash module. The flash module needs some time to change its read voltage. During this time BUSY is set and this flash module cannot be accessed. The other flash modules stay readable.

The argument “MR” defines the read margin:

- 00<sub>H</sub>: normal read margin.
- 01<sub>H</sub>: hard read 0 margin.
- 02<sub>H</sub>: alternate hard read 0 margin.
- 05<sub>H</sub>: hard read 1 margin.
- 06<sub>H</sub>: alternate hard read 1 margin.
- Other values: reserved.

For understanding the read margins please refer to [“Margin Reads” on Page 3-41](#).

This command must not be issued when the flash memory is in page mode or any of the flash modules is in command mode. In this case it is ignored and a sequence error is reported.

*Note:* As noted in [“Margin Control” on Page 3-68](#) the command sequences [“Program Page”](#), [“Erase Sector”](#), [“Erase Page”](#) and [“Erase Security Page”](#) reset the read margin back to 00<sub>H</sub>, i.e. to the normal read margin. The same happens in case of a flash wake-up.

### Enter Page Mode

*Arguments:* PA

### Definition:

```
MOV XXAAH, XX50H
MOV PA, XXAAH
```

*Timing:* 2-cycle command that sets “BUSY” of the addressed flash module for around 20 clock cycles<sup>1)</sup>.

*Description:* The page mode is entered to prepare a page programming operation on page address PA. (Write data are accepted only with the [“Load Page Word”](#) command.)

<sup>1)</sup> When this command is used to abort a page mode of an other flash module the duration increases to around 30 clock cycles.

## Memory Organization

With this command, the IMB Core initializes the write pointer of its block assembly register to zero so that it points to the first word. The page mode is indicated in the status register IMB\_FSR\_BUSY with the PAGE bit, separately for each flash module. The page mode and the read mode are allowed in parallel at the same time and in the same flash module so the flash module stays readable. When the addressed page PA is read the content of the flash memory is delivered. The page mode can be aborted and the related PAGE bit in IMB\_FSR\_BUSY be cleared with the “[Reset to Read](#)” command. A new “[Enter Page Mode](#)” command during page mode aborts the actual page mode, which is indicated with the error flag SQER, and restarts a new page operation. So as mentioned above only one of the flash modules can be in page mode at a time. If one of the erase commands or the “[Change Read Margin](#)” command are received while in page mode it is ignored and a sequence error is reported.

The page mode can be entered in one flash module while others are busy with executing a user data erase or program command, i.e. not while programming or erasing security pages or other blocking sequences.

If write protection is installed for the sector to be programmed, the “[Enter Page Mode](#)” command is only accepted when write protection has before been disabled using the unlock command sequence “[Disable Write Protection](#)” with four passwords. If global write protection is installed with read protection, also the command “[Disable Read Protection](#)” can be used if no sector specific protection is installed. If write protection is not disabled when the “[Enter Page Mode](#)” command is received, the command is not executed, and the protection error flag PROER is set in the IMB\_FSR\_PROT.

*Note: In previous device families (e.g. XC16x) the “Enter Page Mode” did not set “BUSY”. In these devices the “Load Page Word” could be sent directly after issuing “Enter Page Mode”. In XC27x5X it must be waited until “BUSY” clears before sending the “Load Page Word” command sequence.*

### Enter Security Page Mode

*Arguments:* SECPA

*Definition:*

```
MOV XXAAH, XX55H
MOV SECPA, XXAAH
```

*Timing:* 2-cycle command that sets “BUSY” of flash module 0 for around 100 clock cycles.

*Description:* This command is identical to the “[Enter Page Mode](#)” command (see above), with the following exceptions: The addressed page (SECPA) belongs to the security pages of the flash memory and not to the user flash range. This command can only be executed when neither flash write protection nor read protection are active (RPA = 0 and WPA = 0), otherwise it fails with PROER.

## Memory Organization

This command is refused with SQER when any of the flash modules is in command mode.

The use of this command to install passwords and to disable them again is described in “[Protection Handling Details](#)” on Page 3-44.

### Load Page Word

*Arguments:* WD

*Definition:*

MOV XXF2<sub>H</sub>, WD

*Timing:* 1-cycle command that does not set any “BUSY” flags. But note that an immediately following write access to the IMB Core or read from the flash memory is stalled for a few clock cycles if it arrives while the IMB Core is busy with copying its block assembly register content into the flash module assembly buffer. During this stall time the CPU can not perform any action! So either the user software can accept this stall time (which must be taken into account for the worst-case interrupt latency) or the software must avoid the blocking accesses.

*Description:* Load the IMB Core block assembly register with a 16-bit word and increment the write pointer. The 128 byte assembly buffer (i.e. a complete page) is filled by a sequence of 64 “Load Page Word” commands. The word address is not determined by the command but the “[Enter Page Mode](#)” command sets a write word pointer to zero which is incremented after each “[Load Page Word](#)” command.

This (sequential) data write access to the block assembly register belongs to and is only accepted in Page Mode. The command address of this single cycle command is always the same (F2<sub>H</sub>). These low order address bits also identify the “[Load Page Word](#)” command and the sequential write data to be loaded into the block assembly register. The high order bits XX should address the target page. The IMB Core takes always the page address that was used by the last “[Enter Page Mode](#)” command.

When the 128-bit block assembly register of the IMB Core is filled completely after 8 “[Load Page Word](#)” commands the IMB Core calculates the 9 ECC bits and transfers the block into the assembly buffer of the flash module. After that it sets the write pointer of the block assembly register back to zero. The following 8 “[Load Page Word](#)” commands fill again the block. After all 8 blocks are filled the “[Program Page](#)” command can be used to trigger the program process that transfers the assembly buffer content into the flash array.

While the IMB Core transfers the completed block assembly register to the flash module it can not accept new data for a few cycles. A “[Load Page Word](#)” command arriving during this time is stalled by the IMB Core.

If “[Program Page](#)” is called before all blocks of the assembly buffer have received new data then the remaining bits are cleared.

## Memory Organization

If more than 8 times 8 commands are used the additional data is lost. The overflow condition is indicated by the sequence error flag, but the execution of a following “**Program Page**” command is not suppressed (the page mode is not aborted).

When a “**Load Page Word**” command is received and the flash is not in page mode, a sequence error is reported in IMB\_FSR\_OP with SQER flag. In case of a new “**Enter Page Mode**” command or a “**Reset to Read**” command during page mode, or in case of an Application Reset, the write data in the assembly buffer is lost. The current page mode is aborted and in case of a new “**Enter Page Mode**” command entered again for the new address.

### Program Page

*Arguments:* –

*Definition:*

```
MOV XXAAH, XXA0H
MOV XX5AH, XXAAH
```

*Timing:* 2-cycle command that sets “BUSY” of the selected flash module for the whole programming duration. The IMB Core is blocked a few clock cycles after receiving this command and again a few clock cycles before finishing the programming. Write accesses to the flash memory range to execute another command sequence during these times stall the CPU.

*Description:* The assembly buffer of the flash module is programmed into the flash array. If the last block of data was not filled completely this command finalizes its ECC calculation and copies its data into the assembly buffer before it starts the program process. The selection of the flash module and the page to be programmed depends on the page address used by the last “**Enter Page Mode**” command. The user software should always address the targeted page.

The programming process is autonomously performed by the selected flash module. The CPU is not occupied and can continue with its application.

The “**Program Page**” command is only accepted if the addressed flash module is in Page Mode (otherwise, a sequence error is reported instead of execution). With the “**Program Page**” command, the page mode is terminated, indicated by resetting the related PAGE flag and the command mode is entered and the PROG flag in the status register IMB\_FSR\_OP is activated and the related BUSY flag is set in IMB\_FSR\_BUSY.

When the program process has finished BUSY is cleared but PROG stays set. It indicates which operation has finished and will be cleared by a Power-On Reset or by “**Clear Status**”.

Read accesses to the busy flash module are not possible. Reading a busy flash module stalls until the flash module becomes ready again.

## Memory Organization

If write protection is active for the sector to be programmed, the “[Program Page](#)” command is not accepted because the Flash is not in Page Mode (see description of the “[Enter Page Mode](#)” command).

If the page to be programmed is a security page (accepted only in security page mode), the new protection configuration (including keywords or protection confirmation code) is valid directly after execution of this command. During its execution all commands are rejected with a sequence error.

While the IMB Core reads the new protection configuration all DMU accesses to any flash module are stalled.

### Erase Sector

*Arguments:* SA

*Definition:*

```
MOV XXAAH, XX80H
MOV XX54H, XXAAH
MOV SA, XX33H
```

*Timing:* 3-cycle command that sets BUSY of the addressed flash module for the whole erasing duration. The IMB Core is blocked a few clock cycles after receiving this command and again a few clock cycles before finishing the erasing. Write accesses to the flash memory range during these times stall the CPU.

*Description:* The addressed physical sector in the flash array is erased. Following data reads deliver all-zero data with correct ECC.

The erasing process is autonomously performed by the selected flash module. The CPU is not occupied and can continue with its application.

The sector to be erased is addressed by SA (sector address) in the last command cycle.

With the last cycle of the “[Erase Sector](#)” command, the command mode is entered, indicated by activation of the ERASE flag in IMB\_FSR\_OP and after start of erase operation also by the related busy flag in the status register IMB\_FSR\_BUSY. The BUSY flag is cleared after finishing the operation but ERASE stays set. It can be cleared by a Power-On Reset or the “[Clear Status](#)” command.

Read accesses to the busy flash module are not possible. Read accesses to the not busy flash module are especially supported. Reading a busy flash module stalls until the flash module becomes ready again.

If write protection is installed for the sector to be erased, the Erase Sector command is only accepted when write protection has before been disabled using the unlock command sequence “[Disable Write Protection](#)”. If global write protection is installed with read protection, also the command “[Disable Read Protection](#)” can be used if no sector specific protection is installed. If write protection is not disabled when the “[Erase](#)

## Memory Organization

**Sector**" command is received, the command is not executed, and the protection error flag PROER is set in the IMB\_FSR\_PROT.

This command must not be issued when the flash memory is in page mode. In this case it is ignored and a sequence error is reported.

### Erase Page

*Arguments:* PA

*Definition:*

```
MOV XXAAH, XX80H
MOV XX54H, XXAAH
MOV PA, XX03H
```

*Timing:* 3-cycle command that sets BUSY of the addressed flash module for the whole erasing duration. The IMB Core is blocked a few clock cycles after receiving this command and again a few clock cycles before finishing the erasing. Write accesses to the flash memory range during these times stall the CPU.

*Description:* The addressed page is erased. Following data reads deliver all-zero data with correct ECC.

With the last cycle of the "**Erase Page**" command, the command mode is entered, indicated by activation of the ERASE flag in IMB\_FSR\_OP and after start of erase operation also by the related BUSY flag in the status register IMB\_FSR\_BUSY. BUSY is cleared automatically after finishing the operation but ERASE stays set. It is cleared by a Power-On Reset or the "**Clear Status**" command.

Read accesses to the busy flash array are not possible. Read accesses to the not busy flash modules are especially supported. Reading a busy flash module stalls until the flash module becomes ready again.

If the page to be erased belongs to a sector which is write protected, the command is only executed when write protection has before been disabled (see "**Erase Sector**" command).

In case of using the page erase care must be taken not to exceed the drain disturb limit of the other pages of the same sector.

This command must not be issued when the flash memory is in page mode. In this case it is ignored and a sequence error is reported.

### Erase Security Page

*Arguments:* SECPA

*Definition:*

```
MOV XXAAH, XX80H
MOV XX54H, XXA5H
MOV SECPA, XX53H
```

## Memory Organization

*Timing:* 3-cycle command that sets BUSY of flash module 0 for the whole erasing duration.

*Description:* The addressed security page is erased.

This command is identical to the “[Erase Page](#)” command with the following exceptions: The addressed page (SecP0 or SecP1) belongs not to the user visible flash memory range. This command can only be executed after disabling of read protection and of sector write protection.

See “[Protection Handling Examples](#)” on Page 3-51 for a detailed description of re-programming security pages.

The structure of the two security pages (SecP0 and SecP1) is described in “[Layout of the Security Pages](#)” on Page 3-50.

After erasing a security page the new protection configuration (including keywords or protection confirmation code) is valid directly after execution of this command.

While the IMB Core reads the protection configuration all DMU accesses to any flash module are stalled.

This command must not be issued when the flash memory is in page mode or any of the flash modules is in command mode. In this case it is ignored and a sequence error is reported.

## Disable Read Protection

*Arguments:* PWD

*Definition:*

```
MOV XX3CH, XXXXH
MOV XX54H, PWD0
MOV XXAAH, PWD1
MOV XX54H, PWD2
MOV XXAAH, PWD3
MOV XX5AH, XX55H
```

*Timing:* 6-cycle command that does not set any busy flag.

*Description:* Disable temporarily Flash read protection and — if activated — global write protection of the whole flash memory. The RPA bit in IMB\_IMBCTRH is reset.

This is a protected command sequence, using four user defined passwords to release this command or to check the programmed keywords. For every password one command cycle is required. If the second or fourth password represents the code of the “[Reset to Read](#)” command, it is interpreted as password and the reset is not executed.

The 16-bit passwords are internally compared with the keywords out of the “Security Page 0”. If one or more passwords are not identical to their related keywords, the protected sectors remain in the locked state and a protection error (PROER) is indicated in the Flash status register. In this case, a new “[Disable Read Protection](#)” command or

## Memory Organization

a “**Disable Write Protection**” command is only accepted after the next Application Reset.

*Note: During execution of the “Disable Read” (or Write) Protection command a password compare error is only indicated after all four passwords have been compared with the related keywords.*

*Note: This command sequence is also used to check the correctness of keywords before the protection is confirmed in the Security Page 1. A wrong keyword is indicated by the IMB\_FSR\_PROT flag PROER.*

After correct execution of this command, the whole flash memory is unlocked and the read protection disable bit RPRODIS is set in the Flash Status Register (IMB\_FSR\_PROT). Erase and program operations on all sectors are then possible, if the flash memory was also globally write protected (WPA=1), and if they are not separately write protected. The read protection (including global write protection, if so selected) remains disabled until the command “**Re-Enable Read/Write Protection**” is executed, or until the next Application Reset (including HW and SW reset).

This command must not be issued when any of the flash modules is in command mode. In this case it is ignored and a sequence error is reported.

### Disable Write Protection

*Arguments:* PWD

*Definition:*

```
MOV XX3CH, XXXXH
MOV XX54H, PWD0
MOV XXAAH, PWD1
MOV XX54H, PWD2
MOV XXAAH, PWD3
MOV XX5AH, XX05H
```

*Timing:* 6-cycle command that does not set any busy flag.

*Description:* Disable temporarily the global flash write protection or/and the sector write protection of all protected sectors. The WPA bit in IMB\_IMBCTRH is reset.

This is a protected command sequence, using four user defined passwords to release this command (as described above for the “**Disable Read Protection**” command).

After correct execution of this command, all write-protected sectors are unlocked, which is indicated in the Flash Status Register (IMB\_FSR\_PROT) with the WPRODIS bit. Erase and program operations on all sectors are now possible, until

- The command “**Re-Enable Read/Write Protection**” is executed, or
- The next Application Reset (including HW and SW reset) is received.

This command must not be issued when any of the flash modules is in command mode. In this case it is ignored and a sequence error is reported.

## Re-Enable Read/Write Protection

*Arguments:* –

*Definition:*

MOV XX5E<sub>H</sub>, XXXX<sub>H</sub>

*Timing:* 1-cycle command that does not set any busy flags.

*Description:* Flash read and write protection is resumed.

This single-cycle command clears RPRODIS and WPRODIS. The IMB Core is triggered to restore the protection states RPA and WPA from the content of the security page 0 as defined in [Table 3-5 ““Flash State” Determining RPA and WPA” on Page 3-47](#). So in effect this command resumes all kinds of temporarily disabled protection installations.

This command is released immediately after execution.

This command must not be issued when any of the flash modules is in command mode. In this case it is ignored and a sequence error is reported.

## 3.9.5 Sequence Errors

A word (i.e. 16-bit) data move into the flash address range is interpreted by the command interpreter as command sequence. All byte moves are ignored and cause a sequence error which is reported by setting the bit SQER.

As soon the command interpreter detects that the data moves can't be executed as legal sequence it reports the sequence error.

*Note: Data moves addressing not implemented flash areas or powered-down flash modules don't enter the command interpreter and consequently can't cause a sequence error. Usually the next correct command sequence will cause the sequence error because it is interpreted as continuation of the previous one. So instead of checking only for the absence of SQER the other flags (e.g. PAGE, PROG, ERASE) can be further evaluated. For an example see [Section 3.9.6](#).*

Generally each data move received while at least one flash module is BUSY causes a sequence error. But in order to support concurrent execution of command sequences this is under certain conditions not done. A SQER is reported under the following conditions:

- If one of the flash modules is in command mode and the running command does not allow concurrent execution a SQER is reported immediately.
- If at least one of the flash modules is in command mode and the running command allows concurrent execution SQER is only reported when the new command targets a busy flash module.
- If at least one of the flash modules is in command mode SQER is reported as soon as a command cycle is detected that can not belong to a command sequence that allows concurrent execution (i.e. when the received data does not belong to “Enter Page Mode”, “Load Page Word”, “Program Page” or “Erase Page”).

## Memory Organization

The concurrency issues are summarized in **Table 3-4**.

**Table 3-4 Concurrency Issues**

| New sequence while any module is in mode: | Page Mode                    | Busy with normal erase or program | Busy with blocking sequence <sup>1)</sup> |
|-------------------------------------------|------------------------------|-----------------------------------|-------------------------------------------|
| Reset to Read                             | Resets page mode             | SQER <sup>2)</sup>                | SQER <sup>2)</sup>                        |
| Enter Page Mode                           | SQER and Re-enters page mode | OK <sup>3)</sup>                  | SQER                                      |
| Enter Sec. Page Mode                      | SQER and Re-enters page mode | SQER                              | SQER                                      |
| Load Page Word                            | OK                           | OK in page mode                   | SQER/- <sup>4)</sup>                      |
| Program Page                              | OK                           | OK in page mode                   | SQER/- <sup>4)</sup>                      |
| Erase Page/Sector                         | SQER                         | OK <sup>3)</sup>                  | SQER                                      |
| Erase Sec. Page                           | SQER                         | SQER                              | SQER                                      |
| *Protection                               | OK                           | SQER                              | SQER                                      |
| Clear Status                              | OK                           | SQER                              | SQER                                      |
| Change Read Margin                        | SQER                         | SQER                              | SQER                                      |

<sup>1)</sup> "Blocking sequences" are: "Erase Security Page", "Program Page" for a security page, "Change Read Margin", "Enter Page Mode", "Enter Security Page Mode" only while these set busy.

<sup>2)</sup> As described in "[Reset to Read](#)" on [Page 3-27](#) there is one exception to this rule.

<sup>3)</sup> If the new command sequence targets a different flash module that is in read mode else SQER.

<sup>4)</sup> Situation can not occur because "Program Page" is only allowed in page mode and page mode could not be entered.

Other conditions that cause a sequence error were mentioned above in the command descriptions.

### 3.9.6 Instructions for Executing Program and Erase Jobs

## Memory Organization

### Concurrently

All flash modules<sup>1)</sup> can be programmed and erased concurrently. This is however an exceptional case for high-speed flash programming. In the normal case at most one flash module shall be busy while the others can be read.

The limitations reported above in the command sequence descriptions enforce certain behavior for concurrent processes:

- A programming task shall be started in one not interrupted sequence: “Enter Page Mode”, then 64 “Load Page Word” and finally the “Program Page”. No other command sequence on any other flash module shall interrupt this sequence.
- All security page handling shall be done while all flash modules are in read mode.
- Clearing of error and status flags is as well only possible when all flash modules are in read mode. An exception is the flash module specific handling via **IMB\_ECC\_STAT**.
- The IMB Core can only finish an ongoing program or erase task successfully when it is not busy with interpreting a command sequence (i.e. the busy of the ongoing tasks is only cleared when the IMB Core is ready to accept a new command sequence and no new command sequence has been started but not completed).

So the required sequence for programming flash modules concurrently is as follows:

1. Send the “Erase Sector” command sequence to each flash module.
2. Wait until all “BUSY” flags are cleared. During this time the data for programming can be read from external.
3. Send “Enter Page Mode”, 64 “Load Page Word” and the “Program Page” to the first flash module. Continue this sequence with the other flash modules.
4. Wait until all “BUSY” flags are cleared. This time can be used to read the data for programming the next pages from external.
5. Verify the programmed data of all flash modules.
6. Continue the steps 3 to 5 until all pages of the erased sectors are programmed.
7. Continue the steps 1 to 6 until all sectors are programmed.

The recommend sequence which detects incorrect sequences as early as possible is as follows:

1. “Clear Status” and check that SQER is 0.
2. Send the “Erase Sector” command sequence to each flash module. Check for SQER after issuing each sequence.
3. Wait until all “BUSY” flags are cleared. During this time the data for programming can be read from external.
4. Check for SQER which would indicate an incorrectly issued command sequence.

<sup>1)</sup> Additional constraints may apply due to power supply and other device specific reasons. The allowed concurrent processes (including read) are described in the data sheet. This section describes only the logic hardware capabilities.

## Memory Organization

5. “Clear Status” and check again for SQER. If SQER would be set after “Clear Status” a previous “Erase Sector” hasn’t been completed.
6. Send “Enter Page Mode”, check if the PAGE flag was set and check if SQER stays 0, send the 64 “Load Page Word” and the “Program Page” to the first flash module. Check if the PAGE flag is cleared and SQER stays cleared after “Program Page” is accepted. Continue this sequence with the other flash modules.
7. Wait until all “BUSY” flags are cleared. This time can be used to read the data for programming the next pages from external.
8. Verify the programmed data of all flash modules.
9. Continue the steps 6 to 8 until all pages of the erased sectors are programmed.
10. Continue the steps 1 to 9 until all sectors are programmed.

## Memory Organization

### 3.9.7 Data Integrity

This section describes means for detecting and preventing the inadvertent modification of data in the flash memory.

#### 3.9.7.1 Error Correcting Codes (ECC)

With very low probability a flash cell can become disturbed or lose its data value faster than specified. In order to reach the defined overall device reliability each 128-bit block of flash data is accompanied with a 9-bit ECC value. This redundancy supplies SEC-DED capability, meaning “single error correction and double error detection”. All single bit errors are corrected (and the incident is detected), all double bit errors are detected and even most triple bit errors are detected but some of these escape as valid data or corrected data.

A detected error is reported in the register **IMB\_FSR\_PROT** and **IMB\_ECC\_STAT**. Software can select which type of error should trigger a trap by the means of register **IMB\_INTCTR**. In the system control further means exist to modify the handling of errors (see “[SCU Trap Control Registers” on Page 8-184](#)”). The enabled trap requests by the flash module are handled there as “Flash Access Trap”. In case of a double-bit error the read data is always replaced with a dummy data word.

#### 3.9.7.2 Aborted Program/Erase Detection

Where the ECC should protect from intrinsic failures of the flash memory that affect usually only single bits; an interruption of a running program or erase process might cause massive data corruption:

- The erase process programs first all cells to 1 before it erases them. So depending on the time when it is interrupted the data might be in a different state. This can be the old data, all-one, a random value, a weak all-zero or finally all-zero.
- The program process programs all bits concurrently from 0 to 1. If it is interrupted not all set bits might read as 1 or contain a weak 1.

The register **IMB\_FSR\_OP** contains the bits ERASE and PROG. These bits stay set until the next “[Clear Status](#)” command or Power-On Reset. So if an erase or program process is interrupted by an Application Reset one of these bits is still set which allows to detect the interruption. It lies in the responsibility of the software to send the “[Clear Status](#)” command after a finalized program/erase process to enable this evaluation.

Another possible measure against aborted program/erase processes is to prevent resets by configuring the SCU appropriately.

If a program or erase process was aborted by a Power-On Reset (e.g. due to a power failure) there do not exist reliable means to detect this by reading the affected flash range. Even with margin reads an early or late aborted process might go unnoticed although it might in the long-term affect reliability.

## Memory Organization

Therefore the application must ensure that flash processes can perform uninterrupted and under the defined operating conditions, e.g. by early brown-out warning that prevents the software from starting flash processes.

After a flash process aborted the affected address range must be erased and re-programmed.

### 3.9.7.3 Margin Reads

Margin reads can be used to verify that flash data is readable with a certain margin. This is typically used as additional check directly after end-of-line programming. As explained above this is not a reliable method for detecting interrupted program or erase processes but the probability of detecting such cases can be increased.

Reading with “hard read 0 margin” returns weak 0s as 1s and reading with “hard read 1 margin” returns weak 1s as 0s. Changing the read margin is done with the command sequence “**Change Read Margin**” and is reported by the status register “**IMB\_MAR0**”.

### 3.9.7.4 Protection Overview

The flash memory supports read and write protection for the whole memory and separate write protection for each logical sector. The logical sector structure is depicted in [Figure 3-6](#) for a 256 KB array. The logical sector structure of a 64 KB array is equivalent, only the logical sector number 7 to 12 do not exist.

## Memory Organization



## **Figure 3-6 Logical Sectors**

If read protection is installed and active, any flash read access is disabled in case of start after reset from external memory or from internal RAM. Debug access is as well disabled and thus the execution of injected OCDS instructions. In case of start after reset in internal flash, all flash access operations are controlled by the flash-internal user code and are therefore allowed, as long as not especially disabled by the user, e.g. before enabling the debug interface.

Per default, the read protection includes a full (global) flash memory write protection covering all flash modules. This is necessary to eliminate the possibility to program a dump routine into the Flash, which reads the whole Flash and writes it out via the external bus or a serial interface. Program and erase accesses to the flash during active read protection are only possible, if write protection is separately disabled. Flash write

## Memory Organization

and read protection can be temporarily disabled, if the user authorizes himself with correct passwords.

The device also features a sector specific write protection. Software locking of flash memory sectors is provided to protect code and data. This feature disables both program and erase operations for all protected sectors. With write protection it is supported to protect the flash memory or parts of it from unauthorized programming or erase accesses and to provide virus-proof protection for all sectors.

Read and write protection is installed by specific security configuration words which are programmed by the user directly into two "Security Pages" (SecP0/1). After any reset, the security configuration is checked by the command state machine (IMB Core) and installations are stored (and indicated) in related registers. If any protection is enabled also the security pages are especially protected.

For authorization of short-term disabling of read protection or/and of write protection a password checking feature is provided. Only with correct 64-bit password a temporary unprotected state is taken and the protected command sequences are enabled. If not finished by the command "**Re-Enable Read/Write Protection**", the unprotected state is terminated with the next reset. Password checking is based on four 16-bit keywords (together 64 bits) which are programmed by the user directly into the "Security Page 0" (SecP0).

Special support is provided to protect also the protection installation itself against any stressing or beaming aggressors. The codes of configuration bits are selected, so that in case of any violation in the flash array, on the read path or in registers the protected state is taken per default. In registers and security pages, protection control bits are coded always with two bits, having both codes, " $00_B$ " and " $11_B$ " as indication of illegal and therefore protected state.

### 3.9.8 Protection Handling Details

As shortly described in “[Protection Overview](#)” on Page 3-41 the flash memory can be in different protection states. The protection handling can be separated into different layers that interact with each other (see [Figure 3-7](#)).

- The lowest layer consists of the physical content of the security pages SecP0 and SecP1. This information is used to initialize the protection system during startup.
- The next layer consists of registers that report the state of the physical layer (IMB\_PROCONx) and the protection state (IMB\_FSR\_PROT). The protection state can be temporarily changed with command sequences which is reflected in the IMB\_FSR\_PROT.
- The highest layer is represented by 4 fields of the IMB\_IMBCTR register. These fields define the protection rights of the customer software (are read or write accesses currently allowed or not).

The IMB Core controls the protection state of all connected flash modules centrally. In this position it can supervise all accesses that are issued by the CPU.


**Figure 3-7 Protection Layers**

### 3.9.8.1 The Lower Layer “Physical State”

After reset the protection state of the device is restored from the following information:

- The security page 1 contains a “lock code”. This consists of two words of data (32 bits). If it has the value AA55AA55<sub>H</sub> then security page 0 determines the protection state. Otherwise (i.e. the lock code was not found) the device is in the “non-protected state”. The content of the security page 0 is still copied into the registers as described in “[The Middle Layer “Flash State”](#)” on Page 3-46 but their values are ignored in the non-protected state.
- The security page 0 contains the RPRO double bit, the write protection bits SnU and 4 passwords. If the field RPRO contains a valid 01<sub>B</sub> or 10<sub>B</sub> entry the page is valid and the device is in the “protection installed state”. The page content determines the security settings after startup. If SecP0 contains an invalid RPRO entry the device is in the “errored protection” state.

## Memory Organization

To summarize: the content of the security pages determines if the device is in the “non-protected state”, “protection installed state” or “errored protection state”. These states are reflected in the register settings of the next layer.

The device is usually delivered in the “non-protected state”.

The exact layout of the security pages is described in [“Layout of the Security Pages” on Page 3-50](#).

### 3.9.8.2 The Middle Layer “Flash State”

The middle layer consists of the registers IMB\_PROCONx and IMB\_FSR\_PROT and commands that manipulate them and the content of the security pages.

During startup the physical state is examined by the IMB Core and it is reflected in the following bit settings of IMB\_FSR\_PROT:

- “non-protected state”: PROIN = 0, PROINER = 0.
- “protection installed state”: PROIN = 1, PROINER = 0.
- “errored protection state”: PROIN = 0, ROINER = 1.

The fourth possible setting PROIN=1 and PROINER=1 is invalid and can not occur.

The IMB\_PROCONx registers are initialized during startup with the content of the security page 0. The bits DSBER and DDBER indicate if an ECC error occurred. The customer software has thus the possibility to detect disturbed security pages and it can refresh their content.

### Commands

Other bits of the IMB\_FSR\_PROT: RPRODIS, WPRODIS, PROER can be manipulated with command sequences and define together with the other bits the protection effective for the next layer. All three bits are 0 after system startup.

The command [“Disable Read Protection”](#) sets RPRODIS to 1 if the correct passwords that are stored in SecP0 are supplied. If incorrect passwords are entered the bit PROER is set and RPRODIS stays unchanged. As protection against “brute force attacks” that search the correct password the password detection is locked. So after supplying the first incorrect password all following passwords even the correct ones are rejected with PROER. This state is only left by an Application Reset or by erasing SecP0.

The disabled protection can be enabled again by the Application Reset or by the command [“Re-Enable Read/Write Protection”](#) which clears RPRODIS again.

The bit PROER can be reset by an Application Reset or by the commands [“Reset to Read”](#) and [“Clear Status”](#).

The command [“Disable Write Protection”](#) sets WPRODIS to 1 if the correct passwords are supplied. It behaves analog to RPRODIS as described above.

The command [“Re-Enable Read/Write Protection”](#) clears RPRODIS and WPRODIS.

## Memory Organization

The commands “**Enter Page Mode**”, “**Enter Security Page Mode**”, “**Erase Page**”, “**Erase Security Page**” and “**Erase Sector**” set PROER if the write access to the addressed range is not allowed. If a write access is allowed or not is determined by the next level.

**Table 3-5** summarizes how the “Flash State” of protection determines the RPA and WPA fields of IMB\_IMBCTRH. For the double bits a short notation is used here and in the following sections: 1 means active, 0 means inactive, ‘#’ means invalid and ‘-’ means do not care including invalid states. The symbol ‘|’ means logic or.

**Table 3-5 “Flash State” Determining RPA and WPA**

| IMB_FSR.<br>PROI<br>N | IMB_FSR.<br>PROI<br>NER | IMB_FSR.<br>RPR<br>O | IMB_FSR.<br>RPR<br>ODIS | IMB_FSR.<br>WPR<br>ODIS | Resulting Security Level in RPA and WPA                       |
|-----------------------|-------------------------|----------------------|-------------------------|-------------------------|---------------------------------------------------------------|
| 0                     | 0                       | -                    | -                       | -                       | Non-protected state:<br>RPA = 0, WPA = 0.                     |
| 1                     | 0                       |                      |                         |                         | Protection installed state (possibly disabled,<br>see below): |
|                       |                         | 0                    | -                       | 0                       | RPA = 0, WPA = 1.                                             |
|                       |                         | 0                    | 0                       | 1                       | RPA = 0, WPA = 0.                                             |
|                       |                         | 1   #                | 0                       | 0                       | RPA = 1, WPA = 1.                                             |
|                       |                         | -                    | 1                       | 1                       | RPA = 0, WPA = 0 (all disabled).                              |
|                       |                         | 1   #                | 0                       | 1                       | RPA = 1, WPA = 0.                                             |
|                       |                         | 1   #                | 1                       | 0                       | RPA = 0, WPA = 1.                                             |
| 0                     | 1                       |                      |                         |                         | Errored protection state (see below):                         |
|                       |                         | -                    | 0                       | 0                       | RPA = 1, WPA = 1.                                             |
|                       |                         | -                    | 0                       | 1                       | RPA = 1, WPA = 0.                                             |
|                       |                         | -                    | 1                       | 0                       | RPA = 0, WPA = 1.                                             |
|                       |                         | -                    | 1                       | 1                       | RPA = 0, WPA = 0.                                             |

### 3.9.8.3 The Upper Layer “Protection State”

This layer consists mainly of the 4 fields DCF, DDF, WPA and RPA of the IMB\_IMBCTRH register. These determine the effective protection state together with registers of the lower layers. Some of the above mentioned command sequences directly influence these fields as well. In order to increase the resistance against beaming or power supply manipulation all 4 fields are coded with 2 bits. Generally “01”

## Memory Organization

means active, “10” inactive and the two other states “00” and “11” are invalid and are recognized as “attacked” state.

### Effective Security Level

The effective security level based on these 4 double-bits is summarized in [Table 3-6](#) and [Table 3-7](#). For the double bits the same short notation is used as before: 1 means active, 0 means inactive, ‘#’ means invalid and ‘–’ means do not care including invalid states.

**Table 3-6 Effective Read Security**

| RPA   | DCF   | DDF   | Security Level           |
|-------|-------|-------|--------------------------|
| 0     | –     | –     | No read protection.      |
| 1   # | 0     | 0     | No read protection.      |
|       | –     | 1   # | Data reads prohibited.   |
|       | 1   # | –     | Code fetches prohibited. |

**Table 3-7 Effective Write Security**

| WPA   | RPA   | Security Level                                             |
|-------|-------|------------------------------------------------------------|
| 0     | –     | No write protection                                        |
| 1   # | 1   # | Global write protection.                                   |
| 1   # | 0     | Sector specific write protection depending on IMB_PROCONx. |

To summarize:

- Read protection is always globally affecting the whole flash memory range. Code fetches and data reads can be separately controlled.
- Write protection can be global when the read protection is effective or it can be specific for each logical sector.

The lower and the middle security layers determine how the 4 effective IMB\_IMBCTR fields are preset, changed and how software can access them. This is discussed in the following paragraphs.

### Initialization of the Effective Security Level

After Application Reset protection is activated so that RPA, WPA, DDF and DCF are set. During startup the IMB Core determines the stored security level as described in [“The Lower Layer “Physical State”” on Page 3-45](#) and sets IMB\_FSR\_PROT.PROIN and IMB\_FSR\_PROT.PROINER and IMB\_PROCONx as described in [“The Middle Layer](#)

## Memory Organization

**“Flash State” on Page 3-46.** The IMB Core further initializes the IMB\_IMBCTRH fields RPA and WPA according to the rules of [Table 3-5](#).

The bits DDF and DCF of the IMB\_IMBCTRL are not initialized by the IMB Core. During system startup they are initialized depending on the startup condition. If code fetching starts in the flash memory then they are set to the inactive state. In all other cases they are activated to prevent read access to the flash memory without proving password knowledge.

### Changing the Effective Security Level

During run-time the effective security level can be changed. This can be done by directly writing to the IMB\_IMBCTRL register or indirectly by changing the bits of the middle layer by commands as “[Disable Write Protection](#)” or even double indirectly by changing the content of the security pages which changes bits in the middle layer and influences the effective security level.

Writing directly to IMB\_IMBCTRL:

- DCF and DDF can be deactivated only if RPA is inactive. They can always be activated.

Indirectly by using a command sequence:

- A successful “[Disable Read Protection](#)” sets RPRODIS and clears RPA.
- A successful “[Disable Write Protection](#)” sets WPRODIS and clears WPA.
- “[Re-Enable Read/Write Protection](#)” clears RPRODIS and WPRODIS and sets RPA and WPA according to [Table 3-5](#) depending on PROIN, PROINER and RPRO.

Double indirect by changing security pages. After executing a command sequence that changed the content of a security page the IMB Core immediately reads back the pages and determines all resulting security data as described for system startup in “[Initialization of the Effective Security Level](#) on Page 3-48”. The examples in “[Protection Handling Examples](#) on Page 3-51” will show how this can be used for installing and removing protection or changing passwords.

### 3.9.8.4 Reaction on Protection Violation

If software tries to violate the protection rules the following happens:

- Reading data when read protection is effective: The bit IMB\_FSR\_PROT.PROER is set and the Flash access trap can be triggered via the SCU if IMB\_INTCTR.DPROTRP is 0. Default data is delivered.
- Fetching code when read protection is effective: the trap code “TRAP 15<sub>D</sub>” is delivered instead.
- Programming or erasing memory ranges when they are write protected: PROER is set.

## Memory Organization

### 3.9.8.5 Layout of the Security Pages

The previous sections just mentioned the content of the security pages. This section depicts their exact layout. **Figure 3-8** depicts symbolically the layout of the security pages 0 and 1.



**Figure 3-8 Layout of Security Pages**

Generally the 16-bit words are stored as always in the XC27x5X in little endian format.

- The PWx words contain the passwords.
- The double bit RPRO is stored as in the related ISFR **IMB\_FSR\_PROT** in the bits 15 and 14. The other bits of this word are unused and should be kept all-zero.
- The PROCON data is stored as defined in the **IMB\_PROCONx (x=0-3)** ISFR.
- The lock code consists of the two words CL and CH. Both contain “AA55<sub>H</sub>” to form the correct lock code.

## Memory Organization

All bytes of the used blocks of the security pages (block 0 and 1 of SecP0 and block 0 of SecP1) are to be considered as “reserved” and must be kept erased, i.e. with all-zero content. The unused blocks of the security pages (blocks 2 to 7 of SecP0 and blocks 1 to 7 of SecP1) shall be programmed with all-one data.

### 3.9.9 Protection Handling Examples

Some examples on how to work with the protection system.

#### Delivery State

The device is delivered in the “non-protected state”.

Security page 1 is erased (so it does not contain the “lock code” AA55AA55<sub>H</sub>).

Security page 0 is erased and so “invalid” but because SecP1 is erased this data is anyhow not evaluated. Only its content is copied into corresponding the registers.

During startup the bits DDF and DCF are set depending on the start mode but as RPA and WPA are inactive all accesses to the flash memory are allowed.

The data sectors of the flash memory are delivered in the erased state as well. All sectors can be programmed. After uploading the software the customer can install write and read protection.

#### First Time Password Installation

In order to install a password generally the lock code in SecP1 has to be erased. In this case the code is not present.

After that SecP0 must be erased with “**Erase Security Page**” in order to be able to change RPRO. Erasing SecP0 clears RPRO to “00<sub>B</sub>” which is an invalid state. After finishing the erase command the IMB Core restores the IMB\_FSR\_PROT and IMB\_IMBCTRH fields from the flash data.

Because no lock code is present in SecP1 the invalid state of RPRO has no effect on the user visible protection. Still all parts of the flash memory can be written.

The second step is to program the information of SecP0 with the required security information. Again the IMB Core reads immediately back the stored data and initializes the security system. As SecP1 still does not contain the lock code the device stays in the “non-protected” mode.

The security pages cannot be read directly by customer software. The data programmed into SecP0 can therefore only be verified indirectly. The data of the RPRO and SnU fields can be checked by reading the IMB\_PROCON and IMB\_FSR\_PROT registers. The passwords can be verified with the command “**Disable Read Protection**”. If the password does not match the bit PROER is set. But because of the erased SecP1 the flash memory stays writable. So after erasing SecP0 the correct password can be programmed again.

## Memory Organization

After the SecP0 was verified successfully SecP1 gets programmed with the lock code AA55AA55<sub>H</sub> which enables the security settings of SecP0.

Because the password validation left RPRODIS set the command “**Re-Enable Read/Write Protection**” must be used to finally activate the new protection.

### Changing Passwords or Security Settings

Changing the passwords is a delicate operation. The interrelation of the two security pages must be kept in mind.

Usually in the protected state the SecP1 contains the lock code. First write protection must be disabled with the correct passwords. Then the lock code in SecP1 is erased. If this operation was successful PROIN will be cleared by the IMB Core. Now SecP0 can be safely erased.

From this point on the security pages are in the factory delivery state and the new passwords and security settings can be installed as described above.

***Attention: The number of times a security page may be changed is noted in the data sheet.***

## Memory Organization

### 3.9.10 EEPROM Emulation

The flash memory of the XC27x5X is used for three purposes:

1. Storage of program code. Updates happen usually very seldom. The main criteria to be fulfilled is a retention of the life-time of the product.
2. Storage of constant data: this data is stored together with program code. So this data is very seldom updated. Endurance is of no issue here but retention identical to the code memory is required.
3. Data updated during run-time: this might be data with a very high frequency of updates like a mileage counter or access keys for key-less entry. Other data might be changed only in case of failures and other data might only be transferred from RAM to non-volatile memory before the system is powered down.

Especially for the third type of data the non-volatile memory needs EEPROM like characteristics:

- Fine program/erase granularity which is in EEPROMs typically 1 byte.
- Higher endurance than the intrinsic endurance of flash cells.
- Short program and erase duration per byte. Especially for storing data in an emergency (e.g. power failure) short latencies might be required.

A basic requirement for changing data during run-time is that code execution can still resume, especially interrupt requests must still be serviced. This requirement is fulfilled in the XC27x5X because all four flash modules work independently. If one is busy with program or erase then code can still be executed from the other.

The other requirements are more difficult to fulfill because the XC27x5X does not have an EEPROM available but only the flash memory with the already frequently mentioned limitations: big program/erase granularity, moderately long program/erase duration, limited cell endurance with reduced retention at high number of program/erase cycles, pages not isolated but affected by drain disturbs.

In order to alleviate these effects on run-time storage of data software is used to emulate EEPROM. There is quite a number of algorithms for efficiently using flash memory as EEPROM. The following section describes one (the most simple) of these algorithms.

It should be noted that the XC27x5X does not offer the customer any hardware means for EEPROM emulation. All of the following must be realized by software.

#### 3.9.10.1 The Traditional EEPROM Emulation

The key point is to solve the limited endurance by storing data in N different physical places. In XC27x5X the algorithm could use N sequential pages or groups of pages. If data is currently stored in the page group "x" then the next program happens to the page group "(x+1) mod N".

After boot up the last correct page group must be found. This could be done by either evaluating a counter (from 0 to  $2^N - 1$ ) or the old entries are invalidated by erasing the

## Memory Organization

page after programming the new one. Additionally a CRC check could be performed over the group.

As all involved pages are re-used cyclically the endurance from customer perspective is increased by the factor N. N must be chosen high enough to fulfill endurance and retention requirements. Disturbs in the group of N pages are no issue because they incur at most N-1 disturbs before they get written with new data. Care must be taken however if one sector accommodates different groups of pages with different update behavior. In this case the updates of one group of pages could exceed the disturb limits of the other group. So generally one sector should be used only by one such EEPROM cyclic buffer.

The algorithm keeps the old data until the new data is verified so power failure during programming can only destroy the last update but the older data is still available. There are still some issues with power failure that need special treatment:

- Power is cut during programming: the following boot-up might find an apparently correctly programmed page. However the cells might be not fully programmed and thus have a much lower retention or the read data is unstable (e.g. changing operating conditions cause read errors).  
If the power is cut early the page can appear as erased although some cells are partly programmed. When programming different data to this apparently erased page read errors might occur.
- Power is cut during erase: the same as above can happen. Data may appear as erased but the retention is lowered. A power failure during a page-erase can inhibit readability of all data in its physical sector. Therefore an algorithm is advantageous that performs erases only in sectors that don't contain anymore current data.

The algorithm can be improved to be more robust against such cases, e.g. program always two pages, mark the end of an erase process by programming a page. But generally aborting flash processes is a forbidden "operating condition".

The main deficiency of the described algorithm is that the software designer is required to plan the use of the flash memory thoroughly. The user has to choose the correct value of N. Then all data has to be allocated to pages. Data sharing one page should have a similar or better identical update pattern (otherwise unchanged data is unnecessarily written). If one set of data does not fill a complete sector the available pages must be possibly left unused because they might incur too many drain disturbs.

There are other algorithms that try to alleviate these efforts by monitoring the flash usage and adapt automatically the assignment of data to flash cells.

### 3.9.11 Interrupt Generation

Long lasting processes (these are mainly: program page, erase page, erase sector and margin changes, but also enter page mode) set the IMB\_FSR\_BUSY.BUSY flag of one flash module when accepting the request and reset this flag after finishing the process. Software is required to poll the busy flag in order to determine the end of the operation. In order to release the software from this burden an interrupt can be generated. If the interrupt is enabled by IMB\_INTCTRL.IEN then all transitions from 1 to 0 of one of the IMB\_FSR\_BUSY.BUSY flags send an interrupt request to the SCU. In the SCU (see “[SCU Interrupt Generation](#)” on Page 8-147 in the SCU chapter) the interrupt request (noted as “PFI” Program Flash Interrupt) is multiplexed with other interrupt sources and is forwarded to one of four interrupt nodes. The selection of the interrupt node is done with the register field INTNP1.PF. The SCU contains its own set of interrupt status flags (INTSTAT), interrupt disable control (INTDIS) and registers for setting this interrupt (INTSET) and clearing it (INTCLR).

The “[Enter Page Mode](#)” command sets BUSY only for a few clock cycles. It is usually not advisable to enable the interrupt for this command.

The register **IMB\_INTCTR** contains fields for the interrupt status “ISR”, an enable for the interrupt request “IEN” and fields for clearing the status flag “ICLR” or setting if “ISET”. It should be noted that the interrupt request is only sent when ISR becomes 1 and IEN was already 1. No interrupt is sent when IEN becomes 1 when ISR was already 1 or both are set to 1 at the same time.

### 3.9.12 Recommendations for Optimized Flash Usage

This section describes best practices for using the flash in certain application scenarios, e.g. how to use effectively ECC and margin reads. For a description of the hardware features consult “[Data Integrity](#)” on Page 3-40.

#### 3.9.12.1 Programming Code and Constant Data

Code and constant data are programmed only few times during life-time of a device, e.g. end-of-line in ECU production or when service updates are performed. As the readability of this data is decisive for the product quality customers might want to implement the elaborate “best practice” advice.

##### Basic Advice

Always ensure correct operating conditions and prevent power failures during flash operation.

As basic protection against handling errors all data should be verified after programming. Single-bit ECC errors should be ignored. The appearance of small numbers of single-bit errors is a consequence of known physical effects.

## Memory Organization

### Best Practice

This approach offers best possible quality but risks that programming steps need to be repeated even unnecessarily (“false negatives”):

- Use “Erase Sector” to erase complete sectors.
- Program the sector with data. A common protection against software crashes is to fill the unused part of the sector with trap codes.
- Change the read level to hard margin 0.
- Verify the programmed data, note comparison errors and double-bit ECC errors and count single-bit ECC errors. Take care to evaluate the ECC error flags only once per 128-bit data block and clear them afterwards.
- Repeat this check with hard margin 1.
- After programming all sectors:
  - Erase and re-program all sectors with comparison or double-bit ECC errors.
  - If a flash module contained more than a certain number (e.g. 10) of single-bit ECC errors it is recommended to erase and re-program the affected sectors (i.e. those containing at least one single-bit error).
  - Attention: a high number of single-bit errors indicates usually a violation of operating conditions.

The threshold of allowed single-bit errors could be increased for in-service updates in order to reduce the risk of false negatives.

### 3.9.12.2 EEPROM Emulation

For EEPROM emulation the goal is usually not readability over device life-time but highest possible robustness (against violated operating conditions, power failures, even failing flash pages e.g. due to over-cycling). The risk of false negatives should be minimized.

A good robustness is achieved with the following approach:

- Verify data after programming with the normal read level. Single-bit ECC errors should be ignored.
- In case of comparison error or double-bit ECC error the data should be programmed again to the next flash range (e.g. next page or sector).
- The number of re-programming trials should be limited (e.g. to 3) to protect against violated operating conditions.

Obviously this jumping over failed pages can be only used optimally when the algorithm does not expect data on fixed addresses.

Failing pages can prevent “Erase Sector” from erasing any data in the affected sector. The “Erase Page” command however could still erase all other pages. These other pages stay readable and programmable.

## Memory Organization

### 3.10 On-Chip Program Memory Control

The internal memory block “IMB” contains all memories of the so called “on-chip program memory area” in the address range from  $C0'0000_H$  to  $FF'FFFF_H$ . Included are the program SRAM, the embedded flash memories and central control logic called “IMB Core”.

In the XC27x5X device the IMB contains the following memories:

- up to 828 KB flash memory in four independent modules.
- up to 32 KB program SRAM (see [Section 3.4.1](#)).

The IMB connects these memories to the CPU data bus and the instruction fetch bus. Each memory can contain instruction code, data or a mixture of both. The IMB manages accesses to the memories and supports flash programming and erase.

#### 3.10.1 Overview

The [Figure 3-9](#) shows how the IMB and its memories are integrated into the device architecture. Only the main data streams are included. The data buses are usually accompanied by address and control signals and check-sum data like parity or ECC.



**Figure 3-9 IMB Block Diagram**

The CPU has two independent busses. The instruction fetch bus is controlled by the program management unit “PMU” of the CPU. It fetches instructions in aligned groups of 64 bits. The instruction fetch unit of the CPU predicts the outcome of jumps and fetches instructions on the predicted branch in advance. In case of a misprediction this interface

## Memory Organization

can abort outstanding requests and continues fetching on the correct branch. As the CPU can consume up to one 32-bit instruction per clock cycle the performance of this interface determines the CPU performance.

The data bus is controlled by the data management unit “DMU” of the CPU. It reads data in words of 16 bits. Write accesses address as well 16-bit words but additional byte enables allow changing single bytes.

Because of the CPU’s “von Neumann” architecture data and instructions (and “special function registers” to complete the list) share a common address range. When instructions are used as data (e.g. when copying code from an IO interface to the PSRAM) they are accessed via the data bus. The pipelined behavior of the CPU can cause that code fetches and data accesses are requested simultaneously. The IMB takes care that accesses can perform concurrently if they address different memories or flash modules.

Additional connections of the IMB to central system control units exist. These are not shown in the block diagram.

## Memory Organization

### 3.10.2 Register Interface

The “[IMB Registers](#)” on Page 3-59 describes the special function registers of the IMB.

#### 3.10.2.1 IMB Registers

The section describes all IMB special function registers.

**Table 3-8 Registers Overview**

| Register Short Name | Register Long Name         | Offset Address       | Page Number               |
|---------------------|----------------------------|----------------------|---------------------------|
| IMB_IMBCTRL         | IMB Control Low            | FF FF00 <sub>H</sub> | <a href="#">Page 3-60</a> |
| IMB_IMBCTRH         | IMB Control High           | FF FF02 <sub>H</sub> | <a href="#">Page 3-61</a> |
| IMB_INTCTR          | Interrupt Control          | FF FF04 <sub>H</sub> | <a href="#">Page 3-63</a> |
| IMB_FSR_BUSY        | Flash State Busy           | FF FF06 <sub>H</sub> | <a href="#">Page 3-64</a> |
| IMB_FSR_OP          | Flash State Operations     | FF FF08 <sub>H</sub> | <a href="#">Page 3-65</a> |
| IMB_FSR_PROT        | Flash State Protection     | FF FF0A <sub>H</sub> | <a href="#">Page 3-67</a> |
| IMB_MAR0            | Margin 0                   | FF FF0C <sub>H</sub> | <a href="#">Page 3-68</a> |
| IMB_PROCON0         | Protection Configuration 0 | FF FF10 <sub>H</sub> | <a href="#">Page 3-69</a> |
| IMB_PROCON1         | Protection Configuration 1 | FF FF12 <sub>H</sub> | <a href="#">Page 3-69</a> |
| IMB_PROCON2         | Protection Configuration 2 | FF FF14 <sub>H</sub> | <a href="#">Page 3-69</a> |
| IMB_PROCON3         | Protection Configuration 3 | FF FF16 <sub>H</sub> | <a href="#">Page 3-69</a> |
| IMB_ECC_TRAP        | ECC Trap Control           | FF FF20 <sub>H</sub> | <a href="#">Page 3-70</a> |
| IMB_ECC_STAT        | ECC Status                 | FF FF22 <sub>H</sub> | <a href="#">Page 3-72</a> |

#### IMB Control

Global IMB control.

Both IMB\_IMBCTRL and IMB\_IMBCTRH are reset by an Application Reset.

The write access to both registers is controlled by the register security mechanism as defined in the SCU chapter “[Register Control](#)” on Page 8-211. Please note that the register write-protection is not activated automatically again after an access to IMB\_IMBCTR because this happens only for SCU internal registers.

## Memory Organization

**IMB\_IMBCTRL**

IMB Control Low

**ISFR (FF FF00<sub>H</sub>)**
**Reset value: 55AC<sub>H</sub>**

| 15  | 14  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3         | 2       | 1 | 0 |
|-----|-----|----|----|----|----|---|---|---|---|---|---|-----------|---------|---|---|
| DDF | DCF | -  | -  | -  | -  | - | - | - | - | - | - | DLC<br>PF | WSFLASH |   |   |
| rw  | rw  | -  | -  | -  | -  | - | - | - | - | - | - | rw        | rw      |   |   |

| Field   | Bits  | Typ | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WSFLASH | [2:0] | rw  | <p><b>Wait States for Flash Access</b><br/>                     Number of wait cycles after which the IMB expects read data from the flash memory is:<br/> <math>N_{WS} = WSFLASH</math>.<br/>                     This field determines as well the read timing of the PSRAM in the flash emulation address range. See “<a href="#">Flash Emulation” on Page 3-13</a>.<br/>                     The correct setting of this field depends on the system clock frequency. The data sheet of the device describes this relation.<br/> <i>Note: WSFLASH must not be 0. This value is forbidden!</i></p>                                                                                                                                                                                                     |
| DLCPF   | 3     | rw  | <p><b>Disable Linear Code Pre-Fetch</b><br/> <math>0_B</math> “High Speed Mode”: When the next read request will be delivered from the buffer and so the flash memory would be idle, the IMB Core autonomously increments the last address and reads the next 128-bit block from the flash memory.<br/> <math>1_B</math> “Low Power Mode”: This feature is disabled. Usually for code with power minimization requirements or for code with short linear code sections this feature should be disabled (DLCPF = 1). Enabling this feature is only advantageous for code section with longer linear sequences. With lower values of WSFLASH the performance gain of DLCPF=0 is reduced. In case of low WSFLASH settings DLCPF=1 might even lead to better performance than with linear code pre-fetch.</p> |

## Memory Organization

| Field | Bits    | Typ | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|---------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DCF   | [13:12] | rw  | <b>Disable Code Fetch from Flash Memory</b><br>01 <sub>B</sub> Short notation DCF = 1. If RPA = 1 instructions cannot be fetched from flash memory. If RPA = 0 this field has no effect.<br>10 <sub>B</sub> Short notation DCF = 0. Instructions can be fetched independent of RPA.<br>00 <sub>B</sub> Illegal state.<br>11 <sub>B</sub> Illegal state. Both illegal states have the same effect as "01". This state can only be left by an Application Reset.<br>When RPA = 0 software can change this field to any value. Otherwise code fetch can only be disabled but not enabled anymore until the next Application Reset. |
| DDF   | [15:14] | rw  | <b>Disable Data Read from Flash Memory</b><br>01 <sub>B</sub> Short notation DDF = 1. If RPA = 1 data cannot be read from flash memory. If RPA = 0 this field has no effect.<br>10 <sub>B</sub> Short notation DDF = 0. Data can be read independent of RPA.<br>00 <sub>B</sub> Illegal state.<br>11 <sub>B</sub> Illegal state. Both illegal states have the same effect as "01". This state can only be left by an Application Reset.<br>When RPA = 0 software can change this field to any value. Otherwise data reads can only be disabled but not enabled anymore until the next Application Reset.                        |

IMB control high word. The WPA and RPA fields are described in "["Protection Handling Details" on Page 3-44](#).

**IMB\_IMBCTRH**  
**IMB Control High**

**ISFR (FF FF02<sub>H</sub>)**

**Reset value: 0005<sub>H</sub>**



## Memory Organization

| Field  | Bits   | Typ | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|--------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WPA    | [1:0]  | rh  | <p><b>Write Protection Activated</b></p> <p>01<sub>B</sub> Short notation WPA = 1. The write protection of the flash memory is activated.</p> <p>10<sub>B</sub> Short notation WPA = 0. The write protection is not activated.</p> <p>00<sub>B</sub> Illegal state.</p> <p>11<sub>B</sub> Illegal state. Both illegal states have the same effect as "01". This state can only be left by an Application Reset.</p> <p>This field is only changed by the IMB Core. Software writes are ignored.</p>                                 |
| RPA    | [3:2]  | rh  | <p><b>Read Protection Activated</b></p> <p>01<sub>B</sub> Short notation RPA = 1. The read protection of the flash memory is activated.</p> <p>10<sub>B</sub> Short notation RPA = 0. The read protection is not activated.</p> <p>00<sub>B</sub> Illegal state.</p> <p>11<sub>B</sub> Illegal state. Both illegal states have the same effect as "01". This state can only be left by an Application Reset.</p> <p>This field is only changed by the IMB Core. Software writes are ignored.</p>                                    |
| PSPROT | [15:8] | rw  | <p><b>PSRAM Write Protection</b></p> <p>This 8-bit field determines the address up to which the PSRAM is write protected.</p> <p>The start address of the writable range is E0'0000<sub>H</sub> + 1000<sub>H</sub>*PSPROT. The end address is determined by the implemented memory. The equivalent range in the PSRAM area with flash access timing is protected as well. Here the writable range starts at E8'0000<sub>H</sub> + 1000<sub>H</sub>*PSPROT.</p> <p>So with PSPROT=00<sub>H</sub> the complete PSRAM is writable.</p> |

**Interrupt Control**

Interrupt control and status.

Reset by Application Reset.

## Memory Organization

**IMB\_INTCTR**
**Interrupt Control**
**ISFR (FF FF04<sub>H</sub>)**
**Reset value: 0000<sub>H</sub>**

| 15         | 14           | 13 | 12 | 11 | 10               | 9           | 8           | 7 | 6 | 5 | 4 | 3                | 2              | 1              | 0          |
|------------|--------------|----|----|----|------------------|-------------|-------------|---|---|---|---|------------------|----------------|----------------|------------|
| <b>ISR</b> | <b>PSE R</b> | —  | —  | —  | <b>PSE RCL R</b> | <b>ISET</b> | <b>ICLR</b> | — | — | — | — | <b>DPR OTR P</b> | <b>DDD TRP</b> | <b>DIDT RP</b> | <b>IEN</b> |
| rh         | rh           | —  | —  | —  | w                | w           | w           | — | — | — | — | rw               | rw             | rw             | rw         |

| Field   | Bits | Typ | Description                                                                                                                                                                                                                                                                                                                                                    |
|---------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IEN     | 0    | rw  | <b>Interrupt Enable</b><br>If set, the interrupt signal of the IMB gets activated when ISR is set.                                                                                                                                                                                                                                                             |
| DIDTRP  | 1    | rw  | <b>Disable Instruction Fetch Double Bit Error Trap</b><br>If set, a double bit ECC error does not cause the replacement of the fetched data by a trap instruction.<br>See also <a href="#">IMB_ECC_TRAP.DITRPx</a> .                                                                                                                                           |
| DDDTRP  | 2    | rw  | <b>Disable Data Read Double Bit Error Trap</b><br>If set, a double bit ECC error during data read does not send a “Flash Access Error” request to the SCU, i.e. no HW trap is generated and the read data is not replaced with default data. The error flags are still set in IMB_FSR_PROT and IMB_ECC_STAT.<br>See also <a href="#">IMB_ECC_TRAP.DDTRPx</a> . |
| DPROTRP | 3    | rw  | <b>Disable Protection Trap</b><br>If set, a read request from read protected flash memory does not generate a “Flash Access Error” request to the SCU, i.e. no HW trap is generated.                                                                                                                                                                           |
| ICLR    | 8    | w   | <b>Interrupt Clear</b><br>When written with 1 the ISR is cleared. Reading this bit delivers always 0. Writing a 0 is ignored.                                                                                                                                                                                                                                  |
| ISET    | 9    | w   | <b>Interrupt Set</b><br>When written with 1 the ISR is set and if IEN is set the interrupt signal is activated. Reading this bit delivers always 0. Writing a 0 is ignored.                                                                                                                                                                                    |
| PSERCLR | 10   | w   | <b>Clear PSRAM Error Flag</b><br>When written with 1 the PSER is cleared. Reading this bit delivers always 0. Writing a 0 is ignored.                                                                                                                                                                                                                          |

## Memory Organization

| Field | Bits | Typ | Description                                                                                                                                                                                                                                                                                |
|-------|------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PSER  | 14   | rh  | <b>PSRAM Error Flag</b><br>This flag is set when write requests to the write protected or not implemented PSRAM range are detected. This flag can be cleared by writing 1 to PSERCLR.                                                                                                      |
| ISR   | 15   | rh  | <b>Interrupt Service Request</b><br>If set, it indicates that at least one IMB_FSR_BUSY.BUSY bit changed from 1 to 0. If IEN was set an interrupt request is sent to the interrupt controller. After servicing the interrupt the software handler clears this flag by writing a 1 to ICLR. |

**Flash State**

Flash state. Split into 3 registers IMB\_FSR\_BUSY, IMB\_FSR\_OP, and IMB\_FSR\_PROT. The protection relevant fields of IMB\_FSR\_PROT are described in “[Protection Handling Details” on Page 3-44](#).

The registers are reset by the Application Reset with the exception of “ERASE”, “PROG”, and “OPER”. These three fields are only reset by a Power-On Reset.

**IMB\_FSR\_BUSY**
**Flash State Busy**
**ISFR (FF FF06<sub>H</sub>)**
**Reset value: 0000<sub>H</sub>**

| 15 | 14 | 13 | 12 | 11     | 10     | 9      | 8      | 7 | 6 | 5 | 4 | 3      | 2      | 1      | 0      |
|----|----|----|----|--------|--------|--------|--------|---|---|---|---|--------|--------|--------|--------|
| -  | -  | -  | -  | PAG E3 | PAG E2 | PAG E1 | PAG E0 | - | - | - | - | BUS Y3 | BUS Y2 | BUS Y1 | BUS Y0 |
| -  | -  | -  | -  | rh     | rh     | rh     | rh     | - | - | - | - | rh     | rh     | rh     | rh     |

| Field | Bits | Typ | Description                                                                                                                                                                                                                                                                                                              |
|-------|------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BUSY0 | 0    | rh  | <b>Busy Flash 0</b><br>Flash module 0 is busy with a task. The task is indicated by the bits MAR, POWER, ERASE or PROG of IMB_FSR_OP. BUSY0 is automatically cleared when the task has finished. The corresponding task indication is not cleared in order to allow an interrupt handler to determine the finished task. |

## Memory Organization

| Field | Bits | Typ | Description                                                                                                                                                                                                                                                                                                                                           |
|-------|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BUSY1 | 1    | rh  | <b>Busy Flash 1</b><br>Same as BUSY0 for flash module 1.                                                                                                                                                                                                                                                                                              |
| BUSY2 | 2    | rh  | <b>Busy Flash 2</b><br>Same as BUSY0 for flash module 2.                                                                                                                                                                                                                                                                                              |
| BUSY3 | 3    | rh  | <b>Busy Flash 3</b><br>Same as BUSY0 for flash module 3.                                                                                                                                                                                                                                                                                              |
| PAGE0 | 8    | rh  | <b>Page Mode Indication Flash 0</b><br>Set as long the flash module 0 is in page mode. Page mode is entered by the “ <a href="#">Enter Page Mode</a> ” commands and finished by a “ <a href="#">Program Page</a> ” command. The page mode can be also left by a “ <a href="#">Reset to Read</a> ” command. Also an Application Reset clears this bit. |
| PAGE1 | 9    | rh  | <b>Page Mode Indication Flash 1</b><br>Same as PAGE0 for flash module 1.                                                                                                                                                                                                                                                                              |
| PAGE2 | 10   | rh  | <b>Page Mode Indication Flash 2</b><br>Same as PAGE0 for flash module 2.                                                                                                                                                                                                                                                                              |
| PAGE3 | 11   | rh  | <b>Page Mode Indication Flash 3</b><br>Same as PAGE0 for flash module 3.                                                                                                                                                                                                                                                                              |

**IMB\_FSR\_OP**
**Flash State Operations**
**ISFR (FF FF08<sub>H</sub>)**
**Reset value: 0000<sub>H</sub>**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5        | 4        | 3   | 2         | 1         | 0        |
|----|----|----|----|----|----|---|---|---|---|----------|----------|-----|-----------|-----------|----------|
| -  | -  | -  | -  | -  | -  | - | - | - | - | OPE<br>R | SQE<br>R | MAR | POW<br>ER | ERA<br>SE | PRO<br>G |

| Field | Bits | Typ | Description                                                                                                                                                                                                                                                                                                                      |
|-------|------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PROG  | 0    | rh  | <b>Program Task Indication</b><br>This bit is set when a program task is started. The affected flash module is indicated by a BUSY bit. The PROG bit is not automatically reset but must be cleared by a “ <a href="#">Clear Status</a> ” command. This bit is not cleared by an Application Reset but only by a Power-On Reset. |

## Memory Organization

| Field | Bits | Typ | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ERASE | 1    | rh  | <b>Erase Task Indication</b><br>This bit is set when an erase task is started. The affected flash module is indicated by a BUSY bit. The ERASE bit is not automatically reset but must be cleared by a “ <a href="#">Clear Status</a> ” command. This bit is not cleared by an Application Reset but only by a Power-On Reset.                                                                                                                                                                                                                    |
| POWER | 2    | rh  | <b>Power Change Indication</b><br>This bit indicates that a flash module is in its startup phase or in a shutdown phase. The BUSY bits indicate which flash module is busy. This bit is not automatically reset but must be cleared by a “ <a href="#">Clear Status</a> ” command.                                                                                                                                                                                                                                                                |
| MAR   | 3    | rh  | <b>Margin Change Indication</b><br>If a read margin modification is requested this bit is set together with the corresponding BUSY bit. The BUSY bit is cleared when the margin change is effective and the flash module can be read again. The MAR bit must be cleared by a “ <a href="#">Clear Status</a> ” command.                                                                                                                                                                                                                            |
| SQER  | 4    | rh  | <b>Sequence Error</b><br>This bit is set by a errored command sequence or a command that is not accepted. It is cleared by “ <a href="#">Clear Status</a> ” and “ <a href="#">Reset to Read</a> ”.                                                                                                                                                                                                                                                                                                                                                |
| OPER  | 5    | rh  | <b>Operation Error</b><br>The IMB Core maintains internal bits that are set when starting a program or erase process. They are cleared when this process finishes. These bits are not reset by an Application Reset but only by a Power-On Reset. If one of these bits is set after Application Reset the IMB Core sets OPER. So this signals that a running erase or program process was interrupted by an Application Reset.<br>The OPER is cleared by “ <a href="#">Reset to Read</a> ”, “ <a href="#">Clear Status</a> ” or a Power-On Reset. |

## Memory Organization

**IMB\_FSR\_PROT**
**Flash State Protection**
**ISFR (FF FF0A<sub>H</sub>)**
**Reset value: x000<sub>H</sub>**

| 15   | 14 | 13 | 12    | 11    | 10    | 9     | 8 | 7 | 6 | 5 | 4     | 3       | 2       | 1       | 0     |
|------|----|----|-------|-------|-------|-------|---|---|---|---|-------|---------|---------|---------|-------|
| RPRO | -  | -  | DDBER | DSBER | IDBER | ISBER | - | - | - | - | PROER | WPRODIS | RPRODIS | PROINER | PROIN |
| rh   | -  | -  | rh    | rh    | rh    | rh    | - | - | - | - | rh    | rh      | rh      | rh      | rh    |

| Field   | Bits | Typ | Description                                                                                                                                                                                                                                            |
|---------|------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PROIN   | 0    | rh  | <b>Flash Protection Installed</b><br>Modified by the IMB Core. Cleared by Application Reset.                                                                                                                                                           |
| PROINER | 1    | rh  | <b>Flash Protection Installation Error</b><br>Modified by the IMB Core. Cleared by Application Reset.                                                                                                                                                  |
| RPRODIS | 2    | rh  | <b>Read Protection Disabled</b><br>The read protection was temporarily disabled with the “ <a href="#">Disable Read Protection</a> ” command. Modified by the IMB Core. Cleared by Application Reset.                                                  |
| WPRODIS | 3    | rh  | <b>Write Protection Disabled</b><br>The write protection was temporarily disabled with the “ <a href="#">Disable Write Protection</a> ” command. Modified by the IMB Core. Cleared by Application Reset.                                               |
| PROER   | 4    | rh  | <b>Protection Error</b><br>Set by a violation of the installed protection. Reset by the “ <a href="#">Clear Status</a> ” and “ <a href="#">Reset to Read</a> ” commands or an Application Reset.                                                       |
| ISBER   | 8    | rh  | <b>Instruction Fetch Single Bit Error</b><br>Set if during instruction fetch a single-bit ECC error was detected (and corrected). Reset by “ <a href="#">Clear Status</a> ” or “ <a href="#">Reset to Read</a> ” commands or an Application Reset.     |
| IDBER   | 9    | rh  | <b>Instruction Fetch Double Bit Error</b><br>Set if during instruction fetch a double-bit ECC error was detected (and not corrected). Reset by “ <a href="#">Clear Status</a> ” or “ <a href="#">Reset to Read</a> ” commands or an Application Reset. |

## Memory Organization

| Field | Bits    | Typ | Description                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|---------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DSBER | 10      | rh  | <b>Data Read Single Bit Error</b><br>Same as ISBER for data reads.                                                                                                                                                                                                                                                                                                                                     |
| DDBER | 11      | rh  | <b>Data Read Double Bit Error</b><br>Same as IDBER for data reads.                                                                                                                                                                                                                                                                                                                                     |
| RPRO  | [15:14] | rh  | <b>Read Protection Configuration</b><br>This field is copied by the IMB Core from the corresponding field in the security page 0. After Application Reset read protection is activated.<br>See <a href="#">Table 3-5</a> and ff for interpreting this and other protection bit fields.<br>00 <sub>B</sub> Invalid.<br>01 <sub>B</sub> Active.<br>10 <sub>B</sub> Inactive.<br>11 <sub>B</sub> Invalid. |

### Margin Control

Read margin control. Each field corresponds to one flash module. A hard read 0 detects not completely erased cells. These are read as “1”. A hard read 1 detects not completely programmed cells. These are read as “0”. Read margin changes are caused by the command sequence “[Change Read Margin](#)”. The resulting read margin is reflected in this status register.

The command sequences “[Program Page](#)”, “[Erase Sector](#)”, “[Erase Page](#)” and “[Erase Security Page](#)” resets the read margin back to “normal”. The same happens in case of a flash wake-up.

Reset by Application Reset.

### IMB\_MAR0

#### Margin Control 0

ISFR (FF FF0C<sub>H</sub>)

Reset value: 0000<sub>H</sub>

| 15 | 14 | 13 | 12 | 11     | 10 | 9 | 8      | 7  | 6 | 5      | 4  | 3 | 2      | 1  | 0 |
|----|----|----|----|--------|----|---|--------|----|---|--------|----|---|--------|----|---|
| -  | -  | -  | -  | HREAD3 | rh |   | HREAD2 | rh |   | HREAD1 | rh |   | HREAD0 | rh |   |

| Field  | Bits   | Typ | Description                                                                                                                                                                                                                                                                  |
|--------|--------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HREAD0 | [2:0]  | rh  | <b>Hard Read 0</b><br>Active read margin of flash module 0.<br>“000”:Normal read.<br>“001”:Hard read 0.<br>“010”: Alternate hard read 0 (usually harder than 001).<br>“101”:Hard read 1.<br>“110”: Alternate hard read 1 (usually harder than 101).<br>other codes:Reserved. |
| HREAD1 | [5:3]  | rh  | <b>Hard Read 1</b><br>Same as HREAD0 for flash module 1.                                                                                                                                                                                                                     |
| HREAD2 | [8:6]  | rh  | <b>Hard Read 2</b><br>Same as HREAD0 for flash module 2.                                                                                                                                                                                                                     |
| HREAD3 | [11:9] | rh  | <b>Hard Read 3</b><br>Same as HREAD0 for flash module 3.                                                                                                                                                                                                                     |

## Protection Configuration

Protection configuration register of each implemented flash module. The logical sector numbering is depicted in [Figure 3-6](#).

Each bit of the PROCONs is related to a logical sector. If it is cleared the write access to the corresponding logical sector (this means to the range of physical sectors) is locked under the conditions that are documented in [“Protection Handling Details” on Page 3-44](#). The PROCON registers are exclusively modified by the IMB Core which copies them from the security page 0.

For flash modules smaller than 256 KB the SsU bits corresponding to the not implemented flash range are reserved and shall be programmed to 0 in the security page.

Reset by Application Reset.

### IMB\_PROCONx (x=0-3)

Protection Configuration.

ISFR (FF FF10<sub>H</sub>+2\*x)

Reset value: 0000<sub>H</sub>

| 15 | 14 | 13 | 12    | 11    | 10    | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----|----|----|-------|-------|-------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| -  | -  | -  | S12 U | S11 U | S10 U | S9U | S8U | S7U | S6U | S5U | S4U | S3U | S2U | S1U | S0U |

## Memory Organization

| Field        | Bits | Type | Description                                                                                                                                                                                                                                                                                               |
|--------------|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SsU (s=0-12) | s    | rh   | <b>Sector s Unlock</b><br>0 <sub>B</sub> : Logical sector s of flash module x is write-protected.<br>1 <sub>B</sub> : Logical sector s of flash module x is not write-protected.<br><i>Note: In previous device families and the TriCore™ based products these are “lock” bits and not “unlock” bits!</i> |

### ECC Trap Control

ECC trap control register.

Reset by Application Reset.

The register IMB\_ECC\_TRAP allows to disable the double bit ECC error trap generation for selected flash modules in contrast to IMB\_INTCTR which allows to switch this only globally. This selective control enables to operate part of the flash memory as quasi ROM with enabled error traps. But while a flash module is programmed or erased its trap generation can be switched off without affecting the “ROM” modules. Without this facility the traps would have to be globally disabled and the flash driver had to work from SRAM and all interrupts would have to be blocked.

#### IMB\_ECC\_TRAP

##### ECC Trap Control

ISFR (FF FF20<sub>H</sub>)

Reset value: 0000<sub>H</sub>

| 15 | 14 | 13 | 12 | 11         | 10         | 9          | 8          | 7 | 6 | 5 | 4 | 3          | 2          | 1          | 0          |
|----|----|----|----|------------|------------|------------|------------|---|---|---|---|------------|------------|------------|------------|
| 0  | 0  | 0  | 0  | DDT<br>RP3 | DDT<br>RP2 | DDT<br>RP1 | DDT<br>RP0 | 0 | 0 | 0 | 0 | DITR<br>P3 | DITR<br>P2 | DITR<br>P1 | DITR<br>P0 |

## Memory Organization

| Field  | Bits | Typ | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DITRP0 | 0    | rw  | <b>Disable Instruction Fetch Double Bit ECC Trap 0</b><br>0 <sub>B</sub> Replacing instructions by a trap code for double bit ECC errors when fetching from flash module 0 is handled globally via IMB_INTCTR.DIDTRP.<br>1 <sub>B</sub> If set, a double bit ECC error does not cause the replacement of the fetched data by a trap instruction for fetches from flash module 0 independent of IMB_INTCTR.DIDTRP. Additionally IMB_FSR_PROT.ISBER/IDBER are not set for ECC errors from flash module 0.                                               |
| DITRP1 | 1    | rw  | <b>Disable Instruction Fetch Double Bit ECC Trap 1</b><br>Same as DITRP0 for flash module 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| DITRP2 | 2    | rw  | <b>Disable Instruction Fetch Double Bit ECC Trap 2</b><br>Same as DITRP0 for flash module 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| DITRP3 | 3    | rw  | <b>Disable Instruction Fetch Double Bit ECC Trap 3</b><br>Same as DITRP0 for flash module 3.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| DDTRP0 | 8    | rw  | <b>Disable Data Read Double Bit ECC Trap 0</b><br>0 <sub>B</sub> Double bit ECC error trap for data reads from flash module 0 are handled globally via IMB_INTCTR.DDDTRP.<br>1 <sub>B</sub> Double bit ECC error for data reads from flash module 0 does not trigger the “Flash Access Error” trap independent of IMB_INTCTR.DDDTRP. Additionally IMB_FSR_PROT.DSBER/DDBER are not set for ECC errors from flash module 0 and the data from flash memory is delivered not default data. But the bits IMB_ECC_STAT.xBERx are still set for ECC errors. |
| DDTRP1 | 9    | rw  | <b>Disable Data Read Double Bit ECC Trap 1</b><br>Same as DDTRP0 for flash module 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| DDTRP2 | 10   | rw  | <b>Disable Data Read Double Bit ECC Trap 2</b><br>Same as DDTRP0 for flash module 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| DDTRP3 | 11   | rw  | <b>Disable Data Read Double Bit ECC Trap 3</b><br>Same as DDTRP0 for flash module 3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

## Memory Organization

**ECC Status**

ECC status register.

Reset by Application Reset.

This register reports ECC data read single and double bit errors selectively per flash module. Each bit can be cleared independently. This enables to use part of the flash memory quasi as "ROM". In this part all errors trigger traps that are handled by a trap handler and trigger typically a reset of the application. However while flash modules are programmed or erased all ECC errors can be handled by a low-level driver without necessarily affecting the complete system.

**IMB\_ECC\_STAT**

ECC Status

ISFR (FF FF22<sub>H</sub>)

Reset value: 0000<sub>H</sub>

| 15 | 14 | 13 | 12 | 11     | 10     | 9      | 8      | 7 | 6 | 5 | 4 | 3      | 2      | 1      | 0      |
|----|----|----|----|--------|--------|--------|--------|---|---|---|---|--------|--------|--------|--------|
| 0  | 0  | 0  | 0  | DBE R3 | DBE R2 | DBE R1 | DBE R0 | 0 | 0 | 0 | 0 | SBE R3 | SBE R2 | SBE R1 | SBE R0 |
| r  | r  | r  | r  | rwh    | rwh    | rwh    | rwh    | r | r | r | r | rwh    | rwh    | rwh    | rwh    |

| Field | Bits | Typ | Description                                                                                                                                                                        |
|-------|------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SBER0 | 0    | rwh | <b>Data Read Single Bit Error 0</b><br>Set when a single bit ECC errors occurs when reading data from flash module 0.<br>Cleared by Application Reset or by writing 1 to this bit. |
| SBER1 | 1    | rwh | <b>Data Read Single Bit Error 1</b><br>Same as SBER0 for flash module 1.                                                                                                           |
| SBER2 | 2    | rwh | <b>Data Read Single Bit Error 2</b><br>Same as SBER0 for flash module 2.                                                                                                           |
| SBER3 | 3    | rwh | <b>Data Read Single Bit Error 3</b><br>Same as SBER0 for flash module 3.                                                                                                           |
| DBER0 | 8    | rwh | <b>Data Read Double Bit Error 0</b><br>Set when a double bit ECC errors occurs when reading data from flash module 0.<br>Cleared by Application Reset or by writing 1 to this bit. |
| DBER1 | 9    | rwh | <b>Data Read Double Bit Error 1</b><br>Same as DBER0 for flash module 1.                                                                                                           |

## Memory Organization

| Field | Bits | Typ | Description                                                              |
|-------|------|-----|--------------------------------------------------------------------------|
| DBER2 | 10   | rwh | <b>Data Read Double Bit Error 2</b><br>Same as DBER0 for flash module 2. |
| DBER3 | 11   | rwh | <b>Data Read Double Bit Error 3</b><br>Same as DBER0 for flash module 3. |

## Memory Organization

### 3.10.3 Error Reporting Summary

The [Table 3-9](#) summarizes the types of detected errors and the possible reactions.

**Table 3-9 IMB Error Reporting**

| Error                                                      | Reaction                                                                                                                   |
|------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|
| Data read from PSRAM with parity error.                    | If PECON.PEENPS:<br>HW trap (see <a href="#">Section 8.13</a> ).                                                           |
| Instruction fetch from PSRAM with parity error.            | If PECON.PEENPS:<br>HW trap (see <a href="#">Section 8.13</a> ).                                                           |
| Data read from flash memory with single bit error.         | Silently corrected. Bit IMB_FSR_PROT.DSBER set.                                                                            |
| Data read from flash memory with double bit error.         | Bit IMB_FSR_PROT.DDBER set.<br>If IMB_INTCTR.DDDTRP = 0:<br>Flash access trap <sup>1)</sup> and default data is delivered. |
| Instruction fetch from flash memory with single bit error. | Silently corrected. Bit IMB_FSR_PROT.ISBER set.                                                                            |
| Instruction fetch from flash memory with double bit error. | Bit IMB_FSR_PROT.IDBER set.<br>If IMB_INTCTR.DIDTRP = 0:<br>“TRAP 15 <sub>D</sub> ” delivered instead of corrupted data.   |
| Data read from protected flash memory.                     | IMB_FSR_PROT.PROER set.<br>If IMB_INTCTR.DPROTRP = 0:<br>Flash access trap <sup>1)</sup> and default data is delivered.    |
| Instruction fetch from protected flash memory.             | “TRAP 15 <sub>D</sub> ” delivered.                                                                                         |
| Program/erase request of write protected flash range.      | Only bit PROER in IMB_FSR_PROT set.                                                                                        |
| Data read or instruction fetch from busy flash memory.     | Read access stalled until end of busy state.                                                                               |
| Instruction fetch from ISFR addresses.                     | Default data (“TRAP 15 <sub>D</sub> ”) delivered.                                                                          |
| Data read from not implemented ISFRs.                      | Default data delivered.                                                                                                    |
| Data writes to not implemented ISFRs.                      | Silently ignored.                                                                                                          |
| Data read from not implemented address range.              | Unpredictable. Mirrored data from other memories might be returned or default values.                                      |

## Memory Organization

**Table 3-9 IMB Error Reporting (cont'd)**

| Error                                                                                                                               | Reaction                                                                                                                                              |
|-------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Instruction fetch from not implemented address range.                                                                               | Unpredictable. Mirrored data from other memories might be returned or default values.                                                                 |
| Data written to not implemented PSRAM or write protected PSRAM address range (both determined by IMB_IMBCTR.H.PSPROT).              | Bit IMB_INTCTR.PSER set.<br>Flash access trap <sup>1)</sup> and no data is changed in the PSRAM.                                                      |
| Program or erase command targeting not implemented flash memory.                                                                    | Unpredictable. Access is ignored <sup>2)</sup> or mirrored into implemented flash memory <sup>3)</sup> .                                              |
| Data read from powered-down flash modules.                                                                                          | Considered as access to not-implemented memory range. Default data or data from implemented flash modules will be returned.                           |
| Instruction fetch from powered-down flash modules.                                                                                  | Considered as access to not-implemented memory range. Default data ("TRAP 15 <sub>D</sub> ") will be returned or data from implemented flash modules. |
| Program or erase command targeting powered-down flash modules.                                                                      | Silently ignored <sup>2)</sup> .                                                                                                                      |
| Shutdown or power-down request received while the command sequence interpreter is waiting for the last words of a command sequence. | The command interpreter is reset and a "Reset to Read" command sequence is executed.                                                                  |

<sup>1)</sup> More information about the Flash Access Trap can be found in chapter "SCU".

<sup>2)</sup> Attention: when an access (i.e. MOV) is ignored, the command sequence interpreter will still wait for this outstanding MOV. So the next command sequence might cause a SQER because it delivers an unexpected MOV.

<sup>3)</sup> The flash protection can not be by-passed by accessing the reserved memory ranges.

## Memory Organization

### 3.11 Data Retention Memories

This section describes the usage of the special purpose data memories Standby RAM (SBRAM) and Marker Memory (MKMEM). Depending on the device not all of them are available. The XC27x5X contains:

- MKMEM.

## Memory Checker Module (MCHK)

## 4 Memory Checker Module (MCHK)

The memory checker module (MCHK) of the XC27x5X supports checking the data consistency of memories, registers (e.g. configuration registers), or communication channels. It calculates a checksum on a block of data, often called cyclic redundancy code (CRC). It is implemented as a parallel signature generation based on a multi input linear feedback shift register (MISR). Being based on a linear feedback shift register (LFSR), it also can generate pseudo-random numbers and cyclic codes.

This chapter is structured as follows:

- An operational overview of the Memory Checker Module (see [Section 4.1](#))
- Functional description of the Memory Checker Module (see [Section 4.2](#))
- Description of the Memory Checker Module registers (see [Section 4.3](#))
- Description of the general registers (see [Section 4.4](#))
- Interfaces of the Memory Checker Module (see [Section 4.5](#))

### 4.1 Operational Overview

From the programmer's point of view, the MCHK is a set of registers associated with this peripheral. To communicate respective error or operation events a port pin may be used for the signal "MATCH" to generate an external event and an interrupt line may be used for the signal "MISMATCH" to generate an internal event. The MCHK is reset together with the CPU so it can be used as a CPU coprocessor. This ensures a deterministic state of the MCHK after the CPU exits the reset state.



**Figure 4-1 Interface Diagram**

## Memory Checker Module (MCHK)

*Note: The MATCH output is connected to an external port in packaged devices with 144 or more pins only.*

### 4.2 Functional Description

Conventional digital processing systems generally are configured around volatile and non-volatile memory elements. These memories provide (store) the data and instructions to the CPU doing the main computing of an embedded system. This includes the administration of the system by coordinating the operation of various system units to perform system tasks.

Faults within these memories are in general critical for the safety and reliability of an embedded system. Therefore these memories have mechanisms to check for data consistency, e.g. parity or ECC (error correction code). These mechanisms can detect faults up to a certain amount (e.g. double bit faults) per word (bit line faults). Concatenated codes (block codes, word codes) can also detect multibit faults per word (word line faults), which increases the fault coverage.

The MCHK is a parallel signature compression circuitry that calculates a concatenated CRC block code to increase test coverage by code concatenation. This enables error detection within a block of data stored in memory, registers, or communicated e.g. via serial communication lines. The MCHK reduces the probability of error masking due to repeated error patterns by compressing parallel test inputs from a block of data to be tested. Furthermore, it can generate pseudo random numbers.

The MCHK uses a multiple input linear feedback shift register to generate a checksum (signature) of a block of data. A multiple input linear feedback shift register (MISR) is a shift register whose internal feedback input bit is driven by the exclusive-or (XOR) of some bits of the overall shift register value (LFSR: linear feedback shift register).

This generator includes an arithmetic circuitry to calculate the block code. This circuitry is implemented as an independent piece of hardware and, therefore, does not rely on the memories to be tested. Only for the configuration it requires initialization data out of the memories. To avoid the need of a multi master system (CPU, DMA, etc.), the CPU (e.g. PEC, subroutine) is used to handle the data read and write transactions. These transactions rely on the memories to be tested because they may contain the respective CPU instruction code. Therefore the MCHK implements additional measures to enable detection of erroneous data move operations by the CPU.

The following error scenarios are detected:

- The CPU configures the MCHK erroneously
- The CPU does not provide the data from the respective address range
- The CPU does not provide the correct amount of data
- The CPU is not able to check correctly the match of the online generated CRC block code and the expected offline (during development) generated CRC block code

## Memory Checker Module (MCHK)

The principle of this circuitry is to generate an external coded life signal of the CRC block code check. Furthermore the configuration of the circuitry cannot be changed without an external notification. The life signal is not a static signal, but changes polarity in a predefined manner to avoid static faults, e.g. open and short circuit in the output stages.

The circuitry consists of the following components:

- An arithmetic circuitry calculating the CRC block code out of the data transferred into an input register of this circuitry.
- A compare unit to check if the value of the calculated CRC block code is correct. The MCHK compares the content of the CRC block code result registers to a fixed value ( $\text{FADE}'\text{EDDA}_H$ ). Before calculating a CRC value, the result register is initialized with a specific value (magic word, seed), which results in a specific value after the CRC calculation. This so called magic word must be selected in a way that the block code ends up with the fixed value ( $\text{FADE}'\text{EDDA}_H$ ). This works fine for linear code, e.g. the CRC block code.
- A method granting the CRC block code calculation over a given amount of data. Therefore functional redundancy is used to grant this. A local count register within the MCHK initiates the compare of the calculated CRC block code after a given amount of input data. Secondly the CPU reloads the magic word (seed) of the CRC block code when initiating a new CRC block code generation (loop variable within data move subroutine or count register within PEC).
- An internal service request generation to enable software recovery in case of a fault. This could be a software routine running out of a different flash block than the one that produced the error, e.g. to support a limb home function. There is a residual risk: The CPU could write dummy data into the memory checker within this error interrupt routine and then rewrite the COUNT register.
- All configuration registers are protected by a time redundant mechanism. So modifications of configuration registers are only possible following a specific sequence of write operations (EINIT protected). Additionally, the COUNT register is protected by a content dependent access scheme.
- An external MATCH signal is generated on every successful CRC block code generation and may be used to trigger an external window watchdog. This window watchdog may generate a reset in case too many or too few MATCH signal toggles fall into a specific time window. To grant a correctly working block code unit, the application must also perform from time to time a block code generation outside the watchdog time window by having an incorrect compare (no MATCH signal toggle). This will check the correct function of the compare circuitry, because in case of an erroneous compare circuitry a MATCH signal toggle is generated outside the watchdog time window.

## Memory Checker Module (MCHK)

#### 4.2.1 Principle of the LFSR

The list of the bit positions that affect the internal feedback bit is called the tap sequence. **Figure 4-2** shows the principle of an LFSR. It assumes a tap sequence of [32, 26, 23, 22, 16, 12, 11, 10, 8, 7, 5, 4, 2, 1]. On activation, all bits in the LFSR are shifted left one bit position (in direction of the most significant bit). All bits on the tap position are exclusive-ORed and the result is fed into bit 0 as a feedback. On the next activation the same procedure is repeated.

The LFSR outputs that influence the internal feedback input are called taps (marked gray in **Figure 4-2**).



**Figure 4-2 Principle of an LFSR**

### Memory Checker Module (MCHK)

The tap sequence of an LFSR can be represented as a polynomial mod 2. This means that the coefficients of the polynomial must be 0 in case a respective feedback is not implemented or 1 in case a feedback tap is implemented. This is called the feedback polynomial or characteristic polynomial. For example, if the taps are at the 32nd, 26th, 23rd, 22nd, 16th, 12th, 11th, 10th, 8th, 7th, 5th, 4th, and the 2nd bits (as below), the resulting LFSR polynomial is

$$G^{32} = 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 \quad (4.1)$$

The '+1' in the polynomial does not correspond to a tap. The powers of the terms represent the tapped bits, counting from the least significant bit. The polynomial may be represented by a binary number (binary representation). Every power of the terms represent a 1 in the binary format counting from the most significant bit. So for the polynomial listed above, the number would be:

$$G^{32} = 1000\ 0010\ 0110\ 0000\ 1000\ 1110\ 1101\ 1011_B = 8260'8EDB_H$$

The polynomial used by the MCHK is defined in the tap polynomial registers **TPRH** and **TPRL**.

## Memory Checker Module (MCHK)

#### 4.2.2 Principle of the MISR

In parallel to the internal feedback input bit of the LFSR, 16 external bits may be loaded into the LFSR (multiple input).

These 16 input bits are exclusive-ORed with the bits shifted or fed back in the LFSR.



Figure 4-3 Principle of a MISR

The initial value of the LFSR/MISR is called the seed and may be defined by an initial write to the result registers **RRL** and **RRH**. Because the operation of the MISR is deterministic, the sequence of values produced by the MISR is completely determined by its current (or previous) states and inputs.

## Memory Checker Module (MCHK)

### 4.2.3 Commonly used Polynomials

Polynomials for cyclic codes as used in globally standardized systems have not been fully standardized themselves. Most cyclic codes in current use have some weakness with respect to strength or construction. Standardization of cyclic codes would allow for better designed cyclic codes to come into common use. The following table provides a list of common polynomials used for sequential CRC signature generation.

**Table 4-1 Some Commonly used Polynomials**

| Name                | Polynomial                                                                                   | Maximum Data Width            | Normal (Reverse) of Reciprocal                      |
|---------------------|----------------------------------------------------------------------------------------------|-------------------------------|-----------------------------------------------------|
| CRC-8-ATM           | $x^8+x^2+x+1$                                                                                | 8-bit                         | 0000'0083 <sub>H</sub><br>(0000'00C1 <sub>H</sub> ) |
| CRC-8-CCITT         | $x^8+x^7+x^3+x^2+1$                                                                          | 8-bit                         | 0000'00C6 <sub>H</sub>                              |
| CRC-8-Dallas        | $x^8+x^5+x^4+1$                                                                              | 8-bit                         | 0000'0098 <sub>H</sub>                              |
| CRC-8               | $x^8+x^7+x^6+x^4+x^2+1$                                                                      | 8-bit                         | 0000'00EA <sub>H</sub>                              |
| CRC-8<br>SAE J1850  | $x^8+x^4+x^3+x^2+1$                                                                          | 8-bit                         | 0000'008E <sub>H</sub>                              |
| CRC-1<br>(parity)   | $x^8+x^7+x^6+x^5+x^4+x^3+x^2+x+1$                                                            | 8-bit                         | 0000'00FF <sub>H</sub>                              |
| CRC-10              | $x^{10}+x^9+x^5+x^4+x+1$                                                                     | 10-bit                        | 0000'0319 <sub>H</sub><br>(0000'0263 <sub>H</sub> ) |
| CRC-12              | $x^{12}+x^{11}+x^3+x^2+x+1$                                                                  | 12-bit                        | 0000'0C07 <sub>H</sub><br>(0000'0E03 <sub>H</sub> ) |
| CRC-15-CAN          | $x^{15}+x^{14}+x^{10}+x^8+x^7+x^4+x^3+1$                                                     | 15-bit<br>(13-bit)            | 0000'62CC <sub>H</sub><br>(0000'19A3 <sub>H</sub> ) |
| CRC-1<br>(parity)   | $x^{16}+x^{15}+x^{14}+x^{13}+x^{12}+x^{11}+x^{10}+x^9+x^8+x^7+$<br>$x^6+x^5+x^4+x^3+x^2+x+1$ | 16-bit                        | 0000'FFFF <sub>H</sub>                              |
| CRC-16-CCITT        | $x^{16}+x^{12}+x^5+1$                                                                        | 16-bit                        | 0000'8810 <sub>H</sub>                              |
| CRC-16-IBM          | $x^{16}+x^{15}+x^2+1$                                                                        | 16-bit                        | 0000'C002 <sub>H</sub>                              |
| CRC-24-<br>Radix-64 | $x^{24}+x^{23}+x^{18}+x^{17}+x^{14}+x^{11}+x^{10}+x^7+x^6+x^5+$<br>$x^4+x^3+x+1$             | 16-bit<br>(24-bit polynomial) | 00C3'267D <sub>H</sub><br>(BE64'C300 <sub>H</sub> ) |

## Memory Checker Module (MCHK)

**Table 4-1 Some Commonly used Polynomials (cont'd)**

| Name                           | Polynomial                                                                                                              | Maximum Data Width               | Normal (Reverse) of Reciprocal                      |
|--------------------------------|-------------------------------------------------------------------------------------------------------------------------|----------------------------------|-----------------------------------------------------|
| CRC-32-<br>IEEE802.3/<br>MPEG2 | $x^{32}+x^{26}+x^{23}+x^{22}+x^{16}+x^{12}+x^{11}+x^{10}+x^8+x^7+$<br>$x^5+x^4+x^2+x+1$                                 | 16-bit<br>(32-bit polynomial)    | 8260'8ED6 <sub>H</sub><br>(DB71'0641 <sub>H</sub> ) |
| CRC-32C                        | $x^{32}+x^{28}+x^{27}+x^{26}+x^{25}+x^{23}+x^{22}+x^{20}$<br>$+x^{19}+x^{18}+x^{14}+x^{13}+x^{11}+x^{10}+x^9+x^8+x^6+1$ | 16-bit<br>(32/27-bit polynomial) | 8F6E'37A0 <sub>H</sub><br>(05EC'76F1 <sub>H</sub> ) |

*Note: The polynomials above are in general used for sequential signature generation (in general named as CRC), resulting in different signatures than the parallel signature generation algorithm used by the MCHK.*

#### 4.2.4 Architecture of the Memory Checker Module

The LFSR is represented by the Result Register High (**RRH**) and the Result Register Low (**RRL**). These may be used to initialize the MCHK with a seed value. When writing to register RRL, the MISR count register **COUNT** is reloaded with the last value written to register **COUNT**. The result registers **RRH** and **RRL** may be used to read the final or intermediate signature of a block of data loaded into the MCHK.

Data may be loaded into the MCHK by writing either 8-bit or 16-bit data into the MISR input register **IR**. Each write access to register IR decrements the content of the MISR count register **COUNT**.

The polynomial is defined by writing the binary normal reciprocal value into the TAP Polynomial Register High (**TPRH**) and TAP Polynomial Register Low (**TPRL**). The TAP polynomial registers and the result registers are combined by a binary AND. If the amount of ones in the result of this AND operation is odd, a  $1_B$  is fed back, else a  $0_B$ . The effectiveness of the Memory Checker Module is significantly reduced if a polynomial is used with the most significant  $1_B$  bit position in the TAP Polynomial register being smaller than the most significant  $1_B$  in the data fed into the Memory Checker Module. So in general the content of the TAP polynomial register must be larger than  $80_H$  for 8-bit data and larger than  $8000_H$  for 16-bit data.

If the content of the MISR count register **COUNT** is decremented from  $0001_H$  to  $0000_H$ , a service request signal is generated in case the content of the LFSR result register high (**RRH**) is not equal  $FADE_H$  or the content of the LFSR result register low (**RRL**) is not equal  $EDDA_H$ . If the content of the LFSR result registers equals  $FADE'EDDA_H$ , the external MATCH signal is toggled. **Figure 4-4** summarizes the architecture of the checksum circuit.

## Memory Checker Module (MCHK)



Figure 4-4 Implementation of the MCHK Checksum Circuit

## Memory Checker Module (MCHK)

#### 4.2.5 Preferable Usage of the Memory Checker Module

Preferably the MCHK is used together with the CPU. The CPU reads the data block from the selected address area and writes it to the input register **IR**. Alternatively the PEC may be configured to move the data block to input register **IR** using 8-bit or 16-bit moves (PECCx.BWT = 0: 16-bit; PECCx.BWT = 1: 8-bit). Each write operation to register **IR** triggers a intermediate polynomial checksum calculation and the result of the calculation is stored in the result registers **RRL** and **RRH**. Furthermore, every write operation to register **IR** decrements the content of count register **COUNT**.

In order to start a memory check sequence, the result register must be initialized with a seed (e.g. written with the desired start value) and a CPU or PEC transaction must be set up (start address, length, etc.).

When the defined data block is completely written to register **IR**, an interrupt may be generated if the contents of the LFSR result registers **RRH** and **RRL** does not equal FADE'EDDA<sub>H</sub>.

The MCHK may use e.g. the standard Ethernet (IEEE802.3/MPEG2) polynomial, which is given by:

$$G^{32} = 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 \quad (4.2)$$

*Note: Although the polynomial above is used for generation, the result of the parallel signature generation (MISR) differs from the sequential signature generation (LFSR) used by the Ethernet protocol.*

#### 4.2.6 Calculation of Seed Values (Magic Word)

To achieve a successful CRC calculation and MATCH or MISMATCH signal on a block of non volatile data, a data specific seed value, the so called magic word, has to be loaded into the LFSR result registers **RRH** and **RRL** prior to the CRC calculation. This magic word should be calculated during development of the respective data. Such a magic word can only be generated, if the order of the TAP polynomial is equal order 32 (most significant bit of TAP polynomial **TPRH** must be equal 1). Otherwise the higher order bits are non equal to the required end result FADE EDDA<sub>H</sub>. The following program sketches the principle of the program. It uses VBA (Microsoft Visual Basic) syntax. The Data\_Array contains all the 16-bit data the CRC is to be calculated. COUNT passes the number of data the CRC is to be calculated, to the subroutine, as defined in the Memory Checker count register **COUNT**. The magical word is passed back to the calling routine through RRH and RRL, as it has to be written into the Result Register High (**RRH**) and the LFSR Result Register Low (**RRL**) as seed value. Because VBA has no unsigned integer format, a long integer format has been used within this demonstration code.

```
Sub MagicWord(ByRef Data_Array() As Long, _
              ByVal COUNT, TPRH, TPRL As Long, _
              ByRef RRH, RRL As Long)
```

**Memory Checker Module (MCHK)**

```

Dim i, j, order, feedback_bit As Integer
Dim temp As Long
    RRH = &HFADE
    RRL = &HEDDA
For j = COUNT To 1 Step -1
    If TPRH <> 0 Then          ' order of polynomial > 16
        order = 31
        Do While TPRH< 2 ^ (order - 16) ' calculate order of polynomial,
            order = order - 1           ' determines bit position
            Loop                         ' "rolled" out of LFSR
        Else
            order = 15                ' order of polynomial < 17
            Do While TPRL< 2 ^ order   ' calculate order of polynomial,
                order = order - 1       ' determines bit position
                Loop                     ' "rolled" out of LFSR
            End If
        RRL = RRL Xor Data_Array(j)      ' MISR XOR Input
        feedback_bit = RRL And 1         ' Extract CRC feedback bit
        RRL = RRL \ 2                   ' 32 bit shift right (LFSR)
        RRL = RRL + (RRH And 1) * 2 ^ 15
        RRH = RRH \ 2
        temp = (RRH And TPRH) _         ' generate 32 TAP Bits
        Xor (RRL And TPRL)
        For i = 0 To 15
            feedback_bit = feedback_bit _     ' XOR TAP bits to bit
            Xor ((temp \ (2 ^ i)) And 1)
        Next i
        If feedback_bit <> 0 Then        ' TAP feedback bit is equal 1
            If order > 16 Then
                RRH = RRH Or (2 ^ (order - 16))
            Else
                RRL = RRL Xor (2 ^ order)
            End If
        End If
        Next j                          ' calculate CRC of all data
    End Sub

```

## Memory Checker Module (MCHK)

#### 4.2.7 Example Application

Assuming MCHK is to be used to detect faults within a set of twenty one 16 bit Data. The Memory Checker Module uses the standard Ethernet (IEEE802.3/MPEG2) polynomial, which is given by:

$$G^{32} = 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 \quad (4.3)$$

The Polynomial is therefore 8260 8EDB<sub>H</sub> and is written to **TPRH** and **TPRL**. Next the magical word of this set of data has to be calculated offline using a respective program as described in [Section 4.2.6: “Calculation of Seed Values \(Magic Word\)” on Page 4-10](#). For the given data in [Table 4-2](#), a magical word = AA1F ED4E<sub>H</sub> is calculated and written to **RRH** and **RRL**.

**Table 4-2 Example for a CRC Check**

| <b>User Action</b>                    | <b>Data Value</b> | <b>Content of Register</b> |                   |                   |                   |                   |
|---------------------------------------|-------------------|----------------------------|-------------------|-------------------|-------------------|-------------------|
|                                       |                   | <b>COUNT</b>               | <b>RRH</b>        | <b>RRL</b>        | <b>TPRH</b>       | <b>TPRL</b>       |
| TAP Polynomial written to <b>TPRH</b> | 8260 <sub>H</sub> | xxxx                       | xxxx              | xxxx              | 8260 <sub>H</sub> | xxxx              |
| TAP Polynomial written to <b>TPRL</b> | 8EDB <sub>H</sub> | xxxx                       | xxxx              | xxxx              | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Magical Word written into <b>RRH</b>  | AA1F <sub>H</sub> | 0015 <sub>H</sub>          | AA1F <sub>H</sub> | xxxx              | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Magical Word written into <b>RRL</b>  | ED4E <sub>H</sub> | 0015 <sub>H</sub>          | AA1F <sub>H</sub> | ED4E <sub>H</sub> | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Data Amount written to <b>COUNT</b>   | 0015 <sub>H</sub> | 0015 <sub>H</sub>          | xxxx              | xxxx              | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Data 1 written into <b>IR</b>         | 8BED <sub>H</sub> | 0014 <sub>H</sub>          | 543F <sub>H</sub> | 5171 <sub>H</sub> | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Data 2 written into <b>IR</b>         | AA61 <sub>H</sub> | 0013 <sub>H</sub>          | A87E <sub>H</sub> | 0883 <sub>H</sub> | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Data 3 written into <b>IR</b>         | C64E <sub>H</sub> | 0012 <sub>H</sub>          | 50FC <sub>H</sub> | D749 <sub>H</sub> | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Data 4 written into <b>IR</b>         | 17E4 <sub>H</sub> | 0011 <sub>H</sub>          | A1F9 <sub>H</sub> | B976 <sub>H</sub> | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Data 5 written into <b>IR</b>         | A329 <sub>H</sub> | 0010 <sub>H</sub>          | 43F3 <sub>H</sub> | D1C5 <sub>H</sub> | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Data 6 written into <b>IR</b>         | 66B5 <sub>H</sub> | 000F <sub>H</sub>          | 87E7 <sub>H</sub> | C53E <sub>H</sub> | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Data 7 written into <b>IR</b>         | 422A <sub>H</sub> | 000E <sub>H</sub>          | 0FCF <sub>H</sub> | C857 <sub>H</sub> | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Data 8 written into <b>IR</b>         | 4FF6 <sub>H</sub> | 000D <sub>H</sub>          | 1F9F <sub>H</sub> | DF58 <sub>H</sub> | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Data 9 written into <b>IR</b>         | 4046 <sub>H</sub> | 000C <sub>H</sub>          | 3F3F <sub>H</sub> | FEF6 <sub>H</sub> | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Data 10 written into <b>IR</b>        | 911C <sub>H</sub> | 000B <sub>H</sub>          | 7E7F <sub>H</sub> | 6CF0 <sub>H</sub> | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Data 11 written into <b>IR</b>        | 1FA0 <sub>H</sub> | 000A <sub>H</sub>          | FCFE <sub>H</sub> | C640 <sub>H</sub> | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |

## Memory Checker Module (MCHK)

Table 4-2 Example for a CRC Check (cont'd)

| User Action             | Data Value        | Content of Register |                   |                   |                   |                   |
|-------------------------|-------------------|---------------------|-------------------|-------------------|-------------------|-------------------|
|                         |                   | COUNT               | RRH               | RRL               | TPRH              | TPRL              |
| Data 12 written into IR | BF38 <sub>H</sub> | 0009 <sub>H</sub>   | F9FD <sub>H</sub> | 33B9 <sub>H</sub> | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Data 13 written into IR | 9FE3 <sub>H</sub> | 0008 <sub>H</sub>   | F3FA <sub>H</sub> | F891 <sub>H</sub> | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Data 14 written into IR | 44DD <sub>H</sub> | 0007 <sub>H</sub>   | E7F5 <sub>H</sub> | B5FE <sub>H</sub> | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Data 15 written into IR | 749A <sub>H</sub> | 0006 <sub>H</sub>   | CFEB <sub>H</sub> | 1F67 <sub>H</sub> | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Data 16 written into IR | 8C09 <sub>H</sub> | 0005 <sub>H</sub>   | 9FD6 <sub>H</sub> | B2C7 <sub>H</sub> | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Data 17 written into IR | D0F5 <sub>H</sub> | 0004 <sub>H</sub>   | 3FAD <sub>H</sub> | B57A <sub>H</sub> | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Data 18 written into IR | DC5F <sub>H</sub> | 0003 <sub>H</sub>   | 7F5B <sub>H</sub> | B6AB <sub>H</sub> | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Data 19 written into IR | DB06 <sub>H</sub> | 0002 <sub>H</sub>   | FEB7 <sub>H</sub> | B651 <sub>H</sub> | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Data 20 written into IR | 4604 <sub>H</sub> | 0001 <sub>H</sub>   | FD6F <sub>H</sub> | 2AA7 <sub>H</sub> | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |
| Data 21 written into IR | B894 <sub>H</sub> | 0000 <sub>H</sub>   | FADE <sub>H</sub> | EDDA <sub>H</sub> | 8260 <sub>H</sub> | 8EDB <sub>H</sub> |

## Memory Checker Module (MCHK)

### 4.3 Memory Checker Module Registers

From the programmer's point of view, the MCHK is composed of a set of SFRs as summarized below.



**Figure 4-5 Memory Checker Module Kernel Registers**

The following tables show the MCHK registers and their addresses.

**Table 4-3 Registers Address Space**

| Module | Base Address      | End Address | Note |
|--------|-------------------|-------------|------|
| MCHK   | 0000 <sub>H</sub> |             |      |

**Table 4-4 Registers Overview**

| Register Short Name | Register Long Name                      | Offset Address    | Page Number               |
|---------------------|-----------------------------------------|-------------------|---------------------------|
| ID                  | Module Identification Register          | FFE0 <sub>H</sub> | <a href="#">Page 4-20</a> |
| IR                  | Memory Checker Input Register           | FE58 <sub>H</sub> | <a href="#">Page 4-15</a> |
| RRL                 | Memory Checker Result Register Low      | F058 <sub>H</sub> | <a href="#">Page 4-16</a> |
| RRH                 | Memory Checker Result Register High     | F05A <sub>H</sub> | <a href="#">Page 4-16</a> |
| COUNT               | Memory Checker Count Register           | FE5A <sub>H</sub> | <a href="#">Page 4-18</a> |
| TPRL                | Memory Checker Polynomial Register Low  | F05C <sub>H</sub> | <a href="#">Page 4-19</a> |
| TPRH                | Memory Checker Polynomial Register High | F05E <sub>H</sub> | <a href="#">Page 4-19</a> |

*Note: All registers are reset by the same reset class as the CPU is reset.*

**Memory Checker Module (MCHK)**

### 4.3.1 Memory Checker Input Register

The input register receives the data written to the MCHK for checksum calculation. If the CPU moves to register MCHK\_IR are 8-bit wide, the unused register bits of the 16-bit MCHKIN value are taken as 0s for the current result calculation.

**IR**
**Input Register**
**SFR(FE58<sub>H</sub>/2C<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**


| Field  | Bits   | Type | Description                                                                                                                                                      |
|--------|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MCHKIN | [15:0] | w    | <b>Memory Checker Module Input</b><br>The value written to MCHKIN is used for the next checksum calculation.<br>Any read action will deliver 0000 <sub>H</sub> . |

*Note: MCHK\_IR is a write-only register. Any read action will deliver 0000<sub>H</sub>.*

## Memory Checker Module (MCHK)

#### 4.3.2 Memory Checker Result Registers

The result registers contain the signature (result) of the memory check operation. Before starting a checksum calculation operation, they should be written with the initial checksum calculation value (seed).

##### RRL

**Result Register Low**      **ESFR(F058<sub>H</sub>/2C<sub>H</sub>)**      **Reset Value: 0000<sub>H</sub>**



| Field         | Bits   | Type | Description                                                                                                                                                   |
|---------------|--------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>MCHKRL</b> | [15:0] | rwh  | <b>Memory Checker Result Low</b><br>This bit field contains the least significant 16 bits of the current result of the 32-bit checksum calculation operation. |

*Note: Writing to the RRL.MCHKRL will reset (reload) the MCHKCNT.COUNT register to the last data written to this register MCHKCNT.COUNT value. Therefore writing to RRL will immediately initialize a new CRC calculation cycle.*

##### RRH

**Result Register High**      **ESFR(F05A<sub>H</sub>/2D<sub>H</sub>)**      **Reset Value: 0000<sub>H</sub>**



| Field         | Bits   | Type | Description                                                                                                                                                   |
|---------------|--------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>MCHKRH</b> | [15:0] | rwh  | <b>Memory Checker Result High</b><br>This bit field contains the most significant 16 bits of the current result of the 32-bit checksum calculation operation. |

## Memory Checker Module (MCHK)

### 4.3.3 Memory Checker Count Register

The count register COUNT is decremented on each write access to the input register. If the count register is decremented to  $0000_H$ , a service request (interrupt) is generated if the content of the result registers is non equal FADE'EDDA<sub>H</sub>, or instead the output signal MATCH is toggled if the result registers are equal FADE'EDDA<sub>H</sub>. The count register is reloaded with the last value written to it, when the CPU transfers a new seed value (magic word) to the LFSR result register low (**RRL**).

When the CPU or PEC writes to register COUNT and its content is not equal to the last value written to it, the service request (interrupt) is generated and the output signal MATCH is toggled. This enables detection of software not correctly handling the MCHK, e.g. due to an erroneous program memory. The timely correct toggling of the MATCH signal may be used as a life signal e.g. by an external window watchdog. The reset value of the MATCH signal =  $0_B$ .

Because register COUNT controls a safety critical system function, it is protected by a special register security mechanism so this vital system function cannot be changed inadvertently after executing the EINIT instruction.

## Memory Checker Module (MCHK)

**COUNT**
**Count Register**
**SFR(FE5A<sub>H</sub>/2D<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**


| Field          | Bits   | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>MCHKCNT</b> | [15:0] | rwh  | <p><b>Memory Checker Count</b></p> <p>MCHKCNT indicates the number of remaining data in the current data block to be entered into MCHK.</p> <p>0001<sub>H</sub> One remaining data to be written to register <b>IR</b> to trigger the compare for the MATCH signal, interrupt signal NOMATCH.</p> <p>0002<sub>H</sub> Two remaining data to be written to register <b>IR</b>.</p> <p>...<sub>H</sub> ...</p> <p>FFFE<sub>H</sub> 65534 remaining data to be written to register <b>IR</b>.</p> <p>FFFF<sub>H</sub> 65535 remaining data to be written to register <b>IR</b>.</p> <p>0000<sub>H</sub> 65536 remaining data to be written to register <b>IR</b> to trigger the compare for the MATCH signal, interrupt signal NOMATCH.</p> |

*Note: Register COUNT should only be written if MCHKCNT is equal to the last value written to this register. Otherwise, a service request (interrupt) will be triggered and the MATCH signal will be toggled.*

*Modify register COUNT only after writing to register **RRL**, which reloads COUNT to the previously written value (see also [Table 4-2](#)).*

*Note: COUNT is write protected after the execution of EINIT by the register security mechanism.*

#### 4.3.4 Memory Checker Polynomial Registers

The polynomial registers contain the LFSR polynomial of the checksum calculation operation.

**Memory Checker Module (MCHK)**

Because the polynomial registers control a safety critical system function, they are protected by a special register security mechanism so this vital system function cannot be changed inadvertently after executing the EINIT instruction.

**TPRL**
**Tap Polynomial Register Low    ESFR(F05C<sub>H</sub>/2E<sub>H</sub>)                  Reset Value: FFFF<sub>H</sub>**


| Field         | Bits   | Type | Description                                                                                                                        |
|---------------|--------|------|------------------------------------------------------------------------------------------------------------------------------------|
| <b>MCHKPL</b> | [15:0] | rwh  | <b>Memory Checker Polynomial Low</b><br>This bit field contains the least significant 16 bits of the binary tap polynomial format. |

**TPRH**
**Tap Polynomial Register High    ESFR(F05E<sub>H</sub>/2F<sub>H</sub>)                  Reset Value: FFFF<sub>H</sub>**


| Field         | Bits   | Type | Description                                                                                                                        |
|---------------|--------|------|------------------------------------------------------------------------------------------------------------------------------------|
| <b>MCHKPH</b> | [15:0] | rwh  | <b>Memory Checker Polynomial High</b><br>This bit field contains the most significant 16 bits of the binary tap polynomial format. |

*Note: TPRH and TPRL is write protected after the execution of EINIT by the register security mechanism.*

**Memory Checker Module (MCHK)**

## 4.4 General Registers

The ID register is a read-only register used for MCHK module identification purposes. It provides 8 bits for module identification and 8 bits for revision numbering.

### 4.4.1 ID Register

**ID**

| Module Identification Register      MEM(FFE0 <sub>H</sub> )      Reset Value: 3BXX <sub>H</sub> |    |    |    |    |    |   |   |         |   |   |   |   |   |   |   |
|-------------------------------------------------------------------------------------------------|----|----|----|----|----|---|---|---------|---|---|---|---|---|---|---|
| 15                                                                                              | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| MOD_NUMBER                                                                                      |    |    |    |    |    |   |   | MOD_REV |   |   |   |   |   |   |   |
| r                                                                                               |    |    |    |    |    |   |   | r       |   |   |   |   |   |   |   |

| Field      | Bits   | Type | Description                                                                                                                                                                        |
|------------|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MOD_REV    | [7:0]  | r    | <b>Module Revision Number Value</b><br>Bits 7-0 bits are used for module revision numbering. The value of the module revision number starts with 01 <sub>H</sub> (first revision). |
| MOD_NUMBER | [15:8] | r    | <b>Module Identification Number Value</b><br>Bits 15-8 are used for module identification. The MCHK has the module number 3B <sub>H</sub> .                                        |

## 4.5 Interfaces of the MCHK Module

The MCHK module can generate an interrupt request and an external life signal.

The interrupt request signal is connected to the SCU and can be routed to one of the SCU's interrupt nodes.

The MATCH output is connected to an external pin in packaged devices with 144 or more pins only.

**Table 4-5 MCHK Digital Connections in XC27x5X**

| Signal              | from/to<br>Module         | I/O to<br>MCHK  |
|---------------------|---------------------------|-----------------|
| MATCH               | P8.6                      | O               |
| INT (MISMATCH)      | SCU                       | O               |
| MCHKIN_Write_Access | Write trigger from MCHKIN | I <sup>1)</sup> |

## Memory Checker Module (MCHK)

Table 4-5 MCHK Digital Connections in XC27x5X (cont'd)

| Signal               | from/to<br>Module          | I/O to<br>MCHK |
|----------------------|----------------------------|----------------|
| MCHKCNT_Write_Access | Write trigger from MCHKCNT | <sup>1)</sup>  |
| EINIT                | SCU                        |                |

1) This signal is generated within the module itself and is not present at the module boundary.



## Central Processing Unit (CPU)

### 5 Central Processing Unit (CPU)

Basic tasks of the Central Processing Unit (CPU) are to fetch and decode instructions, to supply operands for the Arithmetic and Logic unit (ALU) and the Multiply and Accumulate unit (MAC), to perform operations on these operands in the ALU and MAC, and to store the previously calculated results. As the CPU is the main engine of the XC27x5X microcontroller, it is also affected by certain actions of the peripheral subsystem.

Because a five-stage processing pipeline (plus 2-stage fetch pipeline) is implemented in the XC27x5X, up to five instructions can be processed in parallel. Most instructions of the XC27x5X are executed in one single clock cycle due to this parallelism.

This chapter describes how the pipeline works for sequential and branch instructions in general, and the hardware provisions which have been made to speed up execution of jump instructions in particular. General instruction timing is described, including standard timing, as well as exceptions.

While internal memory accesses are normally performed by the CPU itself, external peripheral or memory accesses are performed by a particular on-chip External Bus Controller (EBC) which is invoked automatically by the CPU whenever a code or data address refers to the external address space.

Whenever possible, the CPU continues operating while an external memory access is in progress. If external data are required but are not yet available, or if a new external memory access is requested by the CPU before a previous access has been completed, the CPU will be held by the EBC until the request can be satisfied. The EBC is described in a separate chapter.

The on-chip peripheral units of the XC27x5X operate independently of the CPU. Data and control information are interchanged between the CPU and these peripherals via Special Function Registers (SFRs) or shared memory areas.

Whenever peripherals need a non-deterministic CPU action, an on-chip Interrupt Controller compares all pending peripheral service requests against each other and prioritizes one of them. If the priority of the current CPU operation is lower than the priority of the selected peripheral request, an interrupt will occur.

There are two basic types of interrupt processing:

- **Standard interrupt processing** forces the CPU to save the current program status and return address on the stack before branching to the interrupt vector jump table.
- **PEC interrupt processing** steals only one machine cycle from the current CPU activity to perform a single data transfer via the on-chip Peripheral Event Controller (PEC).

System errors detected during program execution (hardware traps) and external non-maskable interrupts are also processed as standard interrupts with a very high priority.

## Central Processing Unit (CPU)

In contrast to other on-chip peripherals, there is a closer conjunction between the watchdog timer and the CPU. If enabled, the watchdog timer expects to be serviced by the CPU within a programmable period of time, otherwise it will reset the chip. Thus, the watchdog timer is able to prevent the CPU from going astray when executing erroneous code. The CPU provides a set of instructions for enabling (ENWDT), disabling (DISWDT) and servicing (SRVWDT) the watchdog timer.

In addition to its active operation state, the CPU can enter idle mode by executing the IDLE instruction. In idle mode the CPU stops program execution but still reacts to interrupt or PEC requests. Transition to the active state can be forced by an interrupt request or a hardware reset.

The PWRDN instruction is not enabled in the XC27x5X. If executed a NOP will be performed instead. System power state transitions are controlled by the System Control Unit (SCU).

A set of Special Function Registers is dedicated to the CPU core (CSFRs):

- CPU Status Indication and Control: **PSW, CPUCON1, CPUCON2**
- Code Access Control: **IP, CSP**
- Data Paging Control: **DPP0, DPP1, DPP2, DPP3**
- Global GPRs Access Control: **CP**
- System Stack Access Control: **SP, SPSEG, STKUN, STKOV**
- Multiply and Divide Support: **MDL, MDH, MDC**
- Indirect Addressing Offset: **QR0, QR1, QX0, QX1**
- MAC Address Pointers: **IDX0, IDX1**
- MAC Status Indication and Control: **MCW, MSW, MAH, MAL, MRW**
- ALU Constants Support: **ZEROS, ONES**
- CPU identification: **CPUID**

The CPU also uses CSFRs to access the General Purpose Registers (GPRs). Since all CSFRs can be controlled by any instruction capable of addressing the SFR/CSFR memory space, there is no need for special system control instructions.

However, to ensure proper processor operation, certain restrictions on the user access to some CSFRs must be imposed. For example, the instruction pointer (CSP, IP) cannot be accessed directly at all. These registers can only be changed indirectly via branch instructions. Registers PSW, SP, and MDC can be modified not only explicitly by the programmer, but also implicitly by the CPU during normal instruction processing.

*Note: Note that any explicit write request (via software) to an CSFR supersedes a simultaneous modification by hardware of the same register.*

## Central Processing Unit (CPU)

All CSFRs may be accessed wordwise, or bytewise (some of them even bitwise). Reading bytes from word CSFRs is a non-critical operation. Any write operation to a single byte of a CSFR clears the non-addressed complementary byte within the specified CSFR.

***Attention: Reserved CSFR bits must not be modified explicitly, and will always supply a read value of 0. If a byte/word access is preferred by the programmer or is the only possible access the reserved CSFR bits must be written with 0 to provide compatibility with future versions.***

## Central Processing Unit (CPU)

## 5.1 Components of the CPU

The high performance of the CPU results from the cooperation of several units which are optimized for their respective tasks (see [Figure 5-1](#)). **Prefetch Unit** and **Branch Unit** feed the pipeline minimizing CPU stalls due to instruction reads. The **Address Unit (ADU)** supports sophisticated addressing modes avoiding additional instructions needed otherwise. **Arithmetic and Logic Unit (ALU)** and **Multiply and Accumulate Unit (MAC)** handle differently sized data and execute complex operations. **Three memory interfaces** and **Write Buffer (WB)** minimize CPU stalls due to data transfers.



Figure 5-1 CPU Block Diagram

## Central Processing Unit (CPU)

In general the instructions move through 7 pipeline stages ([Section 5.3](#)). The stages can be grouped as follows:

- **2 stages fetch pipeline** - receives instructions from program memory and stores them into an instruction FIFO. Fetch pipeline stages can be bypassed.
- **5 stages processing pipeline** - executes each instruction received from fetch stages.

Because passing through one pipeline stage takes at least one clock cycle and because the fetch pipeline stages can be bypassed, any isolated instruction takes at least five clock cycles to be completed. Pipelining, however, allows parallel (i.e. simultaneous) processing of up to five instructions (with branches up to six instructions). Therefore, most of the instructions appear to be processed during one clock cycle as soon as the pipeline has been filled once after reset.

The pipelining increases the average instruction throughput considered over a certain period of time.

### 5.2 Instruction Fetch and Program Flow Control

The Instruction Fetch Unit (IFU) prefetches and preprocesses instructions to provide a continuous instruction flow. The IFU can fetch simultaneously at least two instructions via a 64-bit wide bus from the Program Management Unit (PMU). The prefetched instructions are stored in an instruction FIFO.

Preprocessing of branch instructions enables the instruction flow to be predicted. While the CPU is in the process of executing an instruction fetched from the FIFO, the prefetcher of the IFU starts to fetch a new instruction at a predicted target address from the PMU. The latency time of this access is hidden by the execution of the instructions which have already been buffered in the FIFO. Even for a non-sequential instruction execution, the IFU can generally provide a continuous instruction flow. The IFU contains two pipeline stages: the Prefetch Stage and the Fetch Stage.

During the prefetch stage, the Branch Detection and Prediction Logic analyzes up to three prefetched instructions stored in the first Instruction Buffer (can hold up to six instructions). If a branch is detected, then the IFU starts to fetch the next instructions from the PMU according to the prediction rules. After having been analyzed, up to three instructions are stored in the second Instruction Buffer (can hold up to three instructions) which is the input register of the Fetch Stage.

In the case of an incorrectly predicted instruction flow, the instruction fetch pipeline is bypassed to reduce the number of dead cycles.

## Central Processing Unit (CPU)


**Figure 5-2 IFU Block Diagram**

On the Fetch Stage, the prefetched instructions are stored in the instruction FIFO. The Branch Folding Unit (BFU) allows processing of branch instructions in parallel with preceding instructions. To achieve this the BFU preprocesses and reformats the branch instruction. First, the BFU defines (calculates) the absolute target address. This address — after being combined with branch condition and branch attribute bits — is stored in the same FIFO step as the preceding instruction. The target address is also used to prefetch the next instructions.

For the Processing Pipeline, both instructions are fetched from the FIFO again and are executed in parallel. If the instruction flow was predicted incorrectly (or FIFO is empty), the two stages of the IFU can be bypassed.

*Note: Pipeline behavior in case of a incorrectly predicted instruction flow is described in the following sections.*

### 5.2.1 Branch Detection and Branch Prediction Rules

The Branch Detection Unit preprocesses instructions and classifies detected branches. Depending on the branch class, the Branch Prediction Unit predicts the program flow using the following rules:

**Table 5-1 Branch Classes and Prediction Rules**

| Branch Instruction Classes                                   | Instructions                                                                   | Prediction Rule (Assumption)                                                                                                                   |
|--------------------------------------------------------------|--------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Inter-segment branch instructions                            | JMPS seg, caddr<br>CALLS seg, caddr                                            | The branch is always taken                                                                                                                     |
| Branch instructions with user programmable branch prediction | JMPA- xcc, caddr<br>JMPA+ xcc, caddr<br>CALLA- xcc, caddr<br>CALLA+ xcc, caddr | User-specified <sup>1)</sup> via bit 8 ('a') of the instruction long word:<br>...+: branch 'taken' (a = 0)<br>...-: branch 'not taken' (a = 1) |
| Indirect branch instructions                                 | JMPI cc, [Rw]<br>CALLI cc, [Rw]                                                | Unconditional: branch 'taken'<br>Conditional: 'not taken'                                                                                      |
| Relative branch instructions with condition code             | JMPR cc, rel                                                                   | Unconditional or backward: branch 'taken'<br>Conditional forward: 'not taken'                                                                  |
| Relative branch instructions without condition code          | CALLR rel                                                                      | The branch is always taken                                                                                                                     |
| Branch instructions with bit-condition                       | JB(C) bitaddr, rel<br>JNB(S) bitaddr, rel                                      | Backward: branch 'taken'<br>Forward: 'not taken'                                                                                               |
| Return instructions                                          | RET, RETP<br>RETS, RETI                                                        | The branch is always taken                                                                                                                     |

1) This bit can be also set/cleared automatically by the Assembler for generic JMPA and CALLA instructions depending on the jump condition

### 5.2.2 Zero-Cycle Jumps

The “Zero-Cycle Jumps” are one of the advanced XC27x5X specifics, which becomes possible due to the complex pipelined structure for processing instruction-flow.

This feature allows, under some circumstances, jumps to be executed in “null time”. In fact, a jump is “hooked” to the previous instruction and the two instructions pass through the pipeline as one instruction. This can be only possible, if the jump instruction does not need any of the pipeline resources needed by the predecessor. Hence, the following rules are essential:

- a jump can not be hooked onto another jump instruction, as the pipeline resource “target IP” can not be shared between the two;

## Central Processing Unit (CPU)

- a jump can not be executed in zero-cycle if it requires any memory access, as basically any predecessor instruction might access a memory.

The above are only preliminary conditions, needed to make a jump zero-cycle. But would this really happen, it's not reliable enough to predict: it also depends on the exact instruction sequence, speed of the program memory etc.

What can be summarized is:

- only **JMPA**, **JMPR** and **JMPS** Instructions **can be** converted to zero-cycle; **if** the immediately preceding instruction **is not** a branch (any JMP, CALL or RET).
- If a Jump is executed as zero-cycle, in fact the address of this Jump will not be assigned to the Instruction Pointer.

*Note: No IP-Breakpoint must be set over an instruction, which satisfies the two prepositions above for a zero-cycle Jump. Otherwise, if set, it is very possible this Breakpoint will be missed by the debug module.*

### 5.2.3 Atomic and Extend Instructions

The atomic and extend instructions (ATOMIC, EXTR, EXTP, EXTS, EXTPR, EXTSR) disable standard and PEC interrupts and class A traps until completion of the immediately following sequence of instructions. The number of instructions in the sequence may vary from 1 to 4. It is coded in the 2-bit constant field #irang2 and takes values from 0 to 3. The EXTended instructions additionally change the addressing mechanism during this sequence (see instruction description).

ATOMIC and EXTended instructions become active immediately, so no additional NOPs are required. All instructions requiring multi cycles or hold states for execution are considered to be one instruction. The ATOMIC and EXTended instructions can be used with any instruction type.

If a branch instruction following immediately after an atomic sequence is executed as zero-cycle jump, then this branch is part of the atomic sequence as well. If the branch instruction is not a part of the ATOMIC sequence, it should not be hooked on to the atomic sequence, a NOP could be inserted in between.

*Note: If a class B trap interrupt occurs during an ATOMIC or EXTended sequence, then the sequence is terminated, an interrupt lock is removed, and the standard condition is restored before the trap routine is executed. The remaining instructions of the terminated sequence executed after returning from the trap routine will run under standard conditions.*

*Note: When using nested ATOMIC and EXTended instructions. There is only one counter to control the length of the sequence, i.e. issuing an ATOMIC or EXTended instruction within a sequence will reload the counter with the value of the new instruction.*

### 5.3 Instruction Processing Pipeline

The XC27x5X uses five pipeline stages to execute an instruction. All instructions pass through each of the five stages of the instruction processing pipeline. The pipeline stages are listed here together with the 2 stages of the fetch pipeline:

**1st -> PREFETCH:** This stage prefetches instructions from the PMU in the predicted order. The instructions are preprocessed in the branch detection unit to detect branches. The prediction logic decides if the branches are assumed to be taken or not.

**2nd -> FETCH:** The instruction pointer of the next instruction to be fetched is calculated according to the branch prediction rules. For zero-cycle branch execution, the Branch Folding Unit preprocesses and combines detected branches with the preceding instructions. Prefetched instructions are stored in the instruction FIFO. At the same time, instructions are transported out of the instruction FIFO to be executed in the instruction processing pipeline.

**3rd -> DECODE:** The instructions are decoded and, if required, the register file is accessed to read the GPR used in indirect addressing modes.

**4th -> ADDRESS:** All the operand addresses are calculated. Register SP is decremented or incremented for all instructions which implicitly access the system stack.

**5th -> MEMORY:** All the required operands are fetched.

**6th -> EXECUTE:** An ALU or MAC-Unit operation is performed on the previously fetched operands. The condition flags are updated. All explicit write operations to CPU-SFRs and all auto-increment/auto-decrement operations of GPRs used as indirect address pointers are performed.

**7th -> WRITE BACK:** All external operands and the remaining operands within the internal DPRAM space are written back. Operands located in the internal SRAM are buffered in the Write Back Buffer.

Specific so-called injected instructions are generated internally to provide the time needed to process instructions requiring more than one CPU cycle for processing. They are automatically injected into the decode stage of the pipeline, then they pass through the remaining stages like every standard instruction. Program interrupt, PEC transfer, and debug operations are also performed by means of injected instructions. Although these internally injected instructions will not be noticed in reality, they help to explain the operation of the pipeline.

The performance of the CPU (pipeline) is decreased by bandwidth limitations (same resource is accessed by different stages) and data dependencies between instructions. The XC27x5X's CPU has dedicated hardware to detect and to resolve different kinds of dependencies. Some of those dependencies are described in the following section.

Because up to five different instructions are processed simultaneously, additional hardware has been dedicated to deal with dependencies which may exist between instructions in different pipeline stages. This extra hardware supports 'forwarding' of the operand read and write values and resolves most of the possible conflicts — such as

## Central Processing Unit (CPU)

multiple usage of buses — in a time optimized way without performance loss. This makes the pipeline unnoticeable for the user in most cases. However, there are some cases in which the pipeline requires attention by the programmer.

### 5.3.1 Access to the IO Area

Read or write accesses to the IO Areas of the XC27x5X memory space enforce particular pipeline behavior. Thus the requirements of peripheral devices with registers located in these areas are handled appropriately.

The following typical properties of peripheral device registers are considered:

- Upon a write to a peripheral register the contents of any (also multiple) peripheral register(s) may change as a consequence of the write.
- Upon a read from a peripheral register the contents of the same register may change as a consequence of the read (e.g. read buffer of a serial channel)

These cases are handled by following pipeline measures:

#### Write before read execution enforced

If the instructions in the pipeline contain a write action followed by a read action both to the IO areas then the read action is delayed (held in memory stage) until the write action has passed through the writeback stage. Thus the write action will always be scheduled before a read action.

***Attention: Due to additional system delay this does not guarantee that a write will become effective before a read at the target registers.***

Additional system delay is accumulated by the bus system or caused by the peripheral itself. In case the additional read delay differs from the write delay the read may overtake the write. However since the on-chip delays are similar the programmer must take care about this in particular when using off-chip peripherals allocating IO area through the EXTBUS.

#### Prevention of buffered writes

Write access to the IO area is not buffered in the writeback buffer.

### 5.3.2 Pipeline Conflicts

The following examples describe the pipeline behavior in special cases and give provide rules to optimize performance by instruction re-ordering.

***Note: The XC27x5X has a fully interlocked pipeline, which means that pipeline conflicts do not cause any malfunction. Instruction re-ordering is only required for performance reasons.***

## Central Processing Unit (CPU)

### 5.3.2.1 Using General Purpose Registers

The GPRs are the working registers of the CPU and there are a lot of possible dependencies between instructions using GPRs. A high-speed five-port register file prevents bandwidth conflicts. Dedicated hardware is implemented to detect and resolve the data dependencies. Special forwarding buses are used to forward GPR values from one pipeline stage to another. In most cases, this allows the execution of instructions without any delay despite of data dependencies.

Conflict\_GPRs\_Resolved:

|           |            |                            |
|-----------|------------|----------------------------|
| $I_n$     | ADD R0, R1 | ; Compute new value for R0 |
| $I_{n+1}$ | ADD R3, R0 | ; Use R0 again             |
| $I_{n+2}$ | ADD R6, R0 | ; Use R0 again             |
| $I_{n+3}$ | ADD R6, R1 | ; Use R6 again             |

**Table 5-2 Resolved Pipeline Dependencies Using GPRs**

| Stage          | $T_n$                      | $T_{n+1}$                      | $T_{n+2}$                      | $T_{n+3}$                      | $T_{n+4}^{1)}$                 | $T_{n+5}^{2)}$                 |
|----------------|----------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|
| <b>DECODE</b>  | $I_n = \text{ADD } R0, R1$ | $I_{n+1} = \text{ADD } R3, R0$ | $I_{n+2} = \text{ADD } R6, R0$ | $I_{n+3} = \text{ADD } R6, R1$ | $I_{n+4}$                      | $I_{n+5}$                      |
| <b>ADDRESS</b> | $I_{n-1}$                  | $I_n = \text{ADD } R0, R1$     | $I_{n+1} = \text{ADD } R3, R0$ | $I_{n+2} = \text{ADD } R6, R0$ | $I_{n+3} = \text{ADD } R6, R1$ | $I_{n+4}$                      |
| <b>MEMORY</b>  | $I_{n-2}$                  | $I_{n-1}$                      | $I_n = \text{ADD } R0, R1$     | $I_{n+1} = \text{ADD } R3, R0$ | $I_{n+2} = \text{ADD } R6, R0$ | $I_{n+3} = \text{ADD } R6, R1$ |
| <b>EXECUTE</b> | $I_{n-3}$                  | $I_{n-2}$                      | $I_{n-1}$                      | $I_n = \text{ADD } R0, R1$     | $I_{n+1} = \text{ADD } R3, R0$ | $I_{n+2} = \text{ADD } R6, R0$ |
| <b>WR.BACK</b> | $I_{n-4}$                  | $I_{n-3}$                      | $I_{n-2}$                      | $I_{n-1}$                      | $I_n = \text{ADD } R0, R1$     | $I_{n+1} = \text{ADD } R3, R0$ |

1) R0 forwarded from WRITE BACK to MEMORY.

2) R6 forwarded from EXECUTE to MEMORY.

However, if a GPR is used for indirect addressing the address pointer (i.e. the GPR) will be required already in the DECODE stage. In this case the instruction is stalled in the address stage until the operation in the ALU is executed and the result is forwarded to the address stage.

Conflict\_GPRs\_Pointer\_Stall:

|           |              |                             |
|-----------|--------------|-----------------------------|
| $I_n$     | ADD R0, R1   | ; Compute new value for R0  |
| $I_{n+1}$ | MOV R3, [R0] | ; Use R0 as address pointer |
| $I_{n+2}$ | ADD R6, R0   |                             |
| $I_{n+3}$ | ADD R6, R1   |                             |

## Central Processing Unit (CPU)

**Table 5-3 Pipeline Dependencies Using GPRs as Pointers (Stall)**

| Stage          | $T_n$                      | $T_{n+1}$                        | $T_{n+2}^1)$                     | $T_{n+3}^2)$                     | $T_{n+4}$                        | $T_{n+5}$                        |
|----------------|----------------------------|----------------------------------|----------------------------------|----------------------------------|----------------------------------|----------------------------------|
| <b>DECODE</b>  | $I_n = \text{ADD } R0, R1$ | $I_{n+1} = \text{MOV } R3, [R0]$ | $I_{n+2}$                        | $I_{n+2}$                        | $I_{n+2}$                        | $I_{n+3}$                        |
| <b>ADDRESS</b> | $I_{n-1}$                  | $I_n = \text{ADD } R0, R1$       | $I_{n+1} = \text{MOV } R3, [R0]$ | $I_{n+1} = \text{MOV } R3, [R0]$ | $I_{n+1} = \text{MOV } R3, [R0]$ | $I_{n+2}$                        |
| <b>MEMORY</b>  | $I_{n-2}$                  | $I_{n-1}$                        | $I_n = \text{ADD } R0, R1$       | —                                | —                                | $I_{n+1} = \text{MOV } R3, [R0]$ |
| <b>EXECUTE</b> | $I_{n-3}$                  | $I_{n-2}$                        | $I_{n-1}$                        | $I_n = \text{ADD } R0, R1$       | —                                | —                                |
| <b>WR.BACK</b> | $I_{n-4}$                  | $I_{n-3}$                        | $I_{n-2}$                        | $I_{n-1}$                        | $I_n = \text{ADD } R0, R1$       | —                                |

1) New value of R0 not yet available.

2) R0 forwarded from EXECUTE to ADDRESS (next cycle).

To avoid these stalls, one multicycle instruction or two single cycle instructions may be inserted. These instructions must not update the GPR used for indirect addressing.

Conflict\_GPRs\_Pointer\_NoStall:

```

 $I_n = \text{ADD } R0, R1$  ; Compute new value for R0
 $I_{n+1} = \text{ADD } R6, R0$  ; R0 is not updated, just read
 $I_{n+2} = \text{ADD } R6, R1$ 
 $I_{n+3} = \text{MOV } R3, [R0]$  ; Use R0 as address pointer
    
```

**Table 5-4 Pipeline Dependencies Using GPRs as Pointers (No Stall)**

| Stage          | $T_n$                      | $T_{n+1}$                      | $T_{n+2}$                      | $T_{n+3}^1)$                     | $T_{n+4}$                        | $T_{n+5}$                        |
|----------------|----------------------------|--------------------------------|--------------------------------|----------------------------------|----------------------------------|----------------------------------|
| <b>DECODE</b>  | $I_n = \text{ADD } R0, R1$ | $I_{n+1} = \text{ADD } R6, R0$ | $I_{n+2} = \text{ADD } R6, R1$ | $I_{n+3} = \text{MOV } R3, [R0]$ | $I_{n+4}$                        | $I_{n+5}$                        |
| <b>ADDRESS</b> | $I_{n-1}$                  | $I_n = \text{ADD } R0, R1$     | $I_{n+1} = \text{ADD } R6, R0$ | $I_{n+2} = \text{ADD } R6, R1$   | $I_{n+3} = \text{MOV } R3, [R0]$ | $I_{n+4}$                        |
| <b>MEMORY</b>  | $I_{n-2}$                  | $I_{n-1}$                      | $I_n = \text{ADD } R0, R1$     | $I_{n+1} = \text{ADD } R6, R0$   | $I_{n+2} = \text{ADD } R6, R1$   | $I_{n+3} = \text{MOV } R3, [R0]$ |
| <b>EXECUTE</b> | $I_{n-3}$                  | $I_{n-2}$                      | $I_{n-1}$                      | $I_n = \text{ADD } R0, R1$       | $I_{n+1} = \text{ADD } R6, R0$   | $I_{n+2} = \text{ADD } R6, R1$   |
| <b>WR.BACK</b> | $I_{n-4}$                  | $I_{n-3}$                      | $I_{n-2}$                      | $I_{n-1}$                        | $I_n = \text{ADD } R0, R1$       | $I_{n+1} = \text{ADD } R6, R0$   |

1) R0 forwarded from EXECUTE to ADDRESS (next cycle).

## Central Processing Unit (CPU)

### 5.3.2.2 Using Indirect Addressing Modes

In the case of read accesses using indirect addressing modes, the Address Generation Unit uses a speculative addressing mechanism. The read data path to one of the different memory areas (DPRAM, DSRAM, etc.) is selected according to a history table before the address is decoded. This history table has one entry for each of the GPRs. The entries store the information of the last accessed memory area using the corresponding GPR. In the case of an incorrect prediction of the memory area, the read access must be restarted.

It is recommended that the GPRs used for indirect addressing always point to the same memory area. If an updated GPR points to a different memory area, the next read operation will access the wrong memory area. The read access must be repeated, which leads to pipeline stalls.

Conflict\_GPRs\_Pointer\_WrongHistory:

```

In    ADD R3, [R0]      ; R0 points to DPRAM (e.g.)
In+1   MOV R0, R4
...
Ii    MOV DPPX, ...     ; change DPPX
...
Im    ADD R6, [R0]      ; R0 now points to SRAM (e.g.)
Im+1   MOV R6, R1

```

**Table 5-5 Pipeline Dependencies with Pointers (Valid Speculation)**

| Stage          | T <sub>n</sub>                | T <sub>n+1</sub>              | T <sub>n+2</sub>              | T <sub>n+3</sub>              | T <sub>n+4</sub>              | T <sub>n+5</sub>              |
|----------------|-------------------------------|-------------------------------|-------------------------------|-------------------------------|-------------------------------|-------------------------------|
| <b>DECODE</b>  | I <sub>n</sub> = ADD R3, [R0] | I <sub>n+1</sub> = MOV R0, R4 | I <sub>n+2</sub>              | I <sub>n+3</sub>              | I <sub>n+4</sub>              | I <sub>n+5</sub>              |
| <b>ADDRESS</b> | I <sub>n-1</sub>              | I <sub>n</sub> = ADD R3, [R0] | I <sub>n+1</sub> = MOV R0, R4 | I <sub>n+2</sub>              | I <sub>n+3</sub>              | I <sub>n+4</sub>              |
| <b>MEMORY</b>  | I <sub>n-2</sub>              | I <sub>n-1</sub>              | I <sub>n</sub> = ADD R3, [R0] | I <sub>n+1</sub> = MOV R0, R4 | I <sub>n+2</sub>              | I <sub>n+3</sub>              |
| <b>EXECUTE</b> | I <sub>n-3</sub>              | I <sub>n-2</sub>              | I <sub>n-1</sub>              | I <sub>n</sub> = ADD R3, [R0] | I <sub>n+1</sub> = MOV R0, R4 | I <sub>n+2</sub>              |
| <b>WR.BACK</b> | I <sub>n-4</sub>              | I <sub>n-3</sub>              | I <sub>n-2</sub>              | I <sub>n-1</sub>              | I <sub>n</sub> = ADD R3, [R0] | I <sub>n+1</sub> = MOV R0, R4 |

**Table 5-6 Pipeline Dependencies with Pointers (Invalid Speculation)**

| <b>Stage</b>   | <b>T<sub>m</sub></b>             | <b>T<sub>m+1</sub></b>           | <b>T<sub>m+2</sub><sup>1)</sup></b> | <b>T<sub>m+3</sub></b>           | <b>T<sub>m+4</sub></b>           | <b>T<sub>m+5</sub></b>           |
|----------------|----------------------------------|----------------------------------|-------------------------------------|----------------------------------|----------------------------------|----------------------------------|
| <b>DECODE</b>  | I <sub>m</sub> = ADD<br>R6, [R0] | I <sub>m+1</sub> = MOV<br>R6, R1 | I <sub>m+1</sub> = MOV<br>R6, R1    | I <sub>m+2</sub>                 | I <sub>m+3</sub>                 | I <sub>m+4</sub>                 |
| <b>ADDRESS</b> | I <sub>m-1</sub>                 | I <sub>m</sub> = ADD<br>R6, [R0] | I <sub>m</sub> = ADD<br>R6, [R0]    | I <sub>m+1</sub> = MOV<br>R6, R1 | I <sub>m+2</sub>                 | I <sub>m+3</sub>                 |
| <b>MEMORY</b>  | I <sub>m-2</sub>                 | I <sub>m-1</sub>                 | —                                   | I <sub>m</sub> = ADD<br>R6, [R0] | I <sub>m+1</sub> = MOV<br>R6, R1 | I <sub>m+2</sub>                 |
| <b>EXECUTE</b> | I <sub>m-3</sub>                 | I <sub>m-2</sub>                 | I <sub>m-1</sub>                    | —                                | I <sub>m</sub> = ADD<br>R6, [R0] | I <sub>m+1</sub> = MOV<br>R6, R1 |
| <b>WR.BACK</b> | I <sub>m-4</sub>                 | I <sub>m-3</sub>                 | I <sub>m-2</sub>                    | I <sub>m-1</sub>                 | —                                | I <sub>m</sub> = ADD<br>R6, [R0] |

1) Access to location [R0] must be repeated due to wrong history (target area was changed).

### 5.3.2.3 Due to Memory Bandwidth

Memory bandwidth conflicts can occur if instructions in the pipeline access the same memory area at the same time. Special access mechanisms are implemented to minimize conflicts. The DPRAM of the CPU has two independent read/write ports; this allows parallel read and write operation without delays. Write accesses to the DSRAM can be buffered in a Write Back Buffer until read accesses are finished.

All instructions except the CoXXX instructions can read only one memory operand per cycle. A conflict between the read and one write access cannot occur because the DPRAM has two independent read/write ports. Only other pipeline stall conditions can generate a DPRAM bandwidth conflict. The DPRAM is a synchronous pipelined memory. The read access starts with the valid addresses on the address stage. The data are delivered in the Memory stage. If a memory read access is stalled in the Memory stage and the following instruction on the Address stage tries to start a memory read, the new read access must be delayed as well. But, this conflict is hidden by an already existing stall of the pipeline.

The CoXXX instructions are the only instructions able to read two memory operands per cycle. A conflict between the two read and one pending write access can occur if all three operands are located in the DPRAM area. This is especially important for performance in the case of executing a filter routine. One of the operands should be located in the DSRAM to guarantee a single-cycle execution of the CoXXX instructions.

Conflict\_DPRAM\_Bandwidth:

```

In      ADD op1, R1
In+1    ADD R6, R0
In+2    CoMAC [IDX0], [R0]

```

## Central Processing Unit (CPU)

 $I_{n+3} \text{ MOV R3, [R0]}$ 
**Table 5-7 Pipeline Dependencies in Case of Memory Conflicts (DPRAM)**

| Stage          | $T_n$                      | $T_{n+1}$                     | $T_{n+2}$                     | $T_{n+3}$                       | $T_{n+4}^1)$                    | $T_{n+5}$                       |
|----------------|----------------------------|-------------------------------|-------------------------------|---------------------------------|---------------------------------|---------------------------------|
| <b>DECODE</b>  | $I_n = \text{ADD op1, R1}$ | $I_{n+1} = \text{ADD R6, R0}$ | $I_{n+2} = \text{CoMAC ...}$  | $I_{n+3} = \text{MOV R3, [R0]}$ | $I_{n+4}$                       | $I_{n+4}$                       |
| <b>ADDRESS</b> | $I_{n-1}$                  | $I_n = \text{ADD op1, R1}$    | $I_{n+1} = \text{ADD R6, R0}$ | $I_{n+2} = \text{CoMAC ...}$    | $I_{n+3} = \text{MOV R3, [R0]}$ | $I_{n+3} = \text{MOV R3, [R0]}$ |
| <b>MEMORY</b>  | $I_{n-2}$                  | $I_{n-1}$                     | $I_n = \text{ADD op1, R1}$    | $I_{n+1} = \text{ADD R6, R0}$   | $I_{n+2} = \text{CoMAC ...}$    | $I_{n+2} = \text{CoMAC ...}$    |
| <b>EXECUTE</b> | $I_{n-3}$                  | $I_{n-2}$                     | $I_{n-1}$                     | $I_n = \text{ADD op1, R1}$      | $I_{n+1} = \text{ADD R6, R0}$   | –                               |
| <b>WR.BACK</b> | $I_{n-4}$                  | $I_{n-3}$                     | $I_{n-2}$                     | $I_{n-1}$                       | $I_n = \text{ADD op1, R1}$      | $I_{n+1} = \text{ADD R6, R0}$   |

1) COMAC instruction stalls due to memory bandwidth conflict.

The DSRAM is a single-port memory with one read/write port. To reduce the number of bandwidth conflict cases, a Write Back Buffer is implemented. It has three data entries. Only if the buffer is filled and a read access and a write access occur at the same time, must the read access be stalled while one of the buffer entries is written back.

Conflict\_DSRAM\_Bandwidth:

$$\begin{aligned} I_n & \text{ ADD op1, R1} \\ I_{n+1} & \text{ ADD R6, R0} \\ I_{n+2} & \text{ ADD R6, op2} \\ I_{n+3} & \text{ MOV R3, R2} \end{aligned}$$
**Table 5-8 Pipeline Dependencies in Case of Memory Conflicts (DSRAM)**

| Stage          | $T_n$                      | $T_{n+1}$                     | $T_{n+2}$                      | $T_{n+3}$                      | $T_{n+4}^1)$                   | $T_{n+5}$                      |
|----------------|----------------------------|-------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|
| <b>DECODE</b>  | $I_n = \text{ADD op1, R1}$ | $I_{n+1} = \text{ADD R6, R0}$ | $I_{n+2} = \text{ADD R6, op2}$ | $I_{n+3} = \text{MOV R3, R2}$  | $I_{n+4}$                      | $I_{n+4}$                      |
| <b>ADDRESS</b> | $I_{n-1}$                  | $I_n = \text{ADD op1, R1}$    | $I_{n+1} = \text{ADD R6, R0}$  | $I_{n+2} = \text{ADD R6, op2}$ | $I_{n+3} = \text{MOV R3, R2}$  | $I_{n+3} = \text{MOV R3, R2}$  |
| <b>MEMORY</b>  | $I_{n-2}$                  | $I_{n-1}$                     | $I_n = \text{ADD op1, R1}$     | $I_{n+1} = \text{ADD R6, R0}$  | $I_{n+2} = \text{ADD R6, op2}$ | $I_{n+2} = \text{ADD R6, op2}$ |
| <b>EXECUTE</b> | $I_{n-3}$                  | $I_{n-2}$                     | $I_{n-1}$                      | $I_n = \text{ADD op1, R1}$     | $I_{n+1} = \text{ADD R6, R0}$  | –                              |

## Central Processing Unit (CPU)

**Table 5-8 Pipeline Dependencies in Case of Memory Conflicts (DSRAM)**

| Stage            | $T_n$     | $T_{n+1}$ | $T_{n+2}$ | $T_{n+3}$ | $T_{n+4}^1)$           | $T_{n+5}$                 |
|------------------|-----------|-----------|-----------|-----------|------------------------|---------------------------|
| <b>WR.BACK</b>   | $I_{n-4}$ | $I_{n-3}$ | $I_{n-2}$ | $I_{n-1}$ | $I_n = ADD$<br>op1, R1 | $I_{n+1} = ADD$<br>R6, R0 |
| <b>WB.Buffer</b> | full      | full      | full      | full      | full                   | full                      |

1) ADD R6, op2 instruction stalls due to memory bandwidth conflict.

### 5.3.2.4 Caused by CPU-SFR Updates

CPU-SFRs control the CPU functionality and behavior. Changes and updates of CSFRs influence the instruction flow in the pipeline. Therefore, special care is required to ensure that instructions in the pipeline always work with the correct CSFR values. CSFRs are updated late on the EXECUTE stage of the pipeline. Meanwhile, without conflict detection, the instructions in the DECODE, ADDRESS, and MEMORY stages would still work without updated register values. The CPU detects conflict cases and stalls the pipeline to guarantee a correct execution. For performance reasons, the CPU differentiates between different classes of CPU-SFRs. The flow of instructions through the pipeline can be improved by following the given rules used for instruction re-ordering.

There are three classes of CPU-SFRs:

- CSFRs not generating pipeline conflicts (ONES, ZEROS, MCW)
- CSFR result registers updated late in the EXECUTE stage, causing one stall cycle
- CSFRs affecting the whole CPU or the pipeline, causing a pipeline cancelation

### CSFR Result Registers

The CSFR result registers MDH, MDL, MSW, MAH, MAL, and MRW of the ALU and MAC-Unit are updated late in the EXECUTE stage of the pipeline. If an instruction (except CoSTORE) accesses these registers in the MEMORY stage, the value cannot be forwarded. The instruction must be stalled for one cycle on the MEMORY stage.

Conflict\_CSFR\_Update\_Stall:

```

 $I_n$       MUL R0,R1
 $I_{n+1}$     MOV R6,MDL
 $I_{n+2}$     ADD R6,R1
 $I_{n+3}$     MOV R3,[R0]

```

## Central Processing Unit (CPU)

**Table 5-9 Pipeline Dependencies with Result CSFRs (Stall)**

| Stage          | $T_n$                 | $T_{n+1}$                  | $T_{n+2}$                  | $T_{n+3}^1)$                | $T_{n+4}$                   | $T_{n+5}$                   |
|----------------|-----------------------|----------------------------|----------------------------|-----------------------------|-----------------------------|-----------------------------|
| <b>DECODE</b>  | $I_n = MUL$<br>R0, R1 | $I_{n+1} = MOV$<br>R6, MDL | $I_{n+2} = ADD$<br>R6, R1  | $I_{n+3} = MOV$<br>R3, [R0] | $I_{n+3} = MOV$<br>R3, [R0] | $I_{n+4}$                   |
| <b>ADDRESS</b> | $I_{n-1}$             | $I_n = MUL$<br>R0, R1      | $I_{n+1} = MOV$<br>R6, MDL | $I_{n+2} = ADD$<br>R6, R1   | $I_{n+2} = ADD$<br>R6, R1   | $I_{n+3} = MOV$<br>R3, [R0] |
| <b>MEMORY</b>  | $I_{n-2}$             | $I_{n-1}$                  | $I_n = MUL$<br>R0, R1      | $I_{n+1} = MOV$<br>R6, MDL  | $I_{n+1} = MOV$<br>R6, MDL  | $I_{n+2} = ADD$<br>R6, R1   |
| <b>EXECUTE</b> | $I_{n-3}$             | $I_{n-2}$                  | $I_{n-1}$                  | $I_n = MUL$<br>R0, R1       | —                           | $I_{n+1} = MOV$<br>R6, MDL  |
| <b>WR.BACK</b> | $I_{n-4}$             | $I_{n-3}$                  | $I_{n-2}$                  | $I_{n-1}$                   | $I_n = MUL$<br>R0, R1       | —                           |

1) Cannot read MDL here.

By reordering instructions, the bubble in the pipeline can be filled with an instruction not using this resource.

Conflict\_CSFR\_Update\_Resolved:

```

 $I_n = MUL R0, R1$ 
 $I_{n+1} = MOV R3, [R0]$ 
 $I_{n+2} = MOV R6, MDL$ 
 $I_{n+3} = ADD R6, R1$ 

```

**Table 5-10 Pipeline Dependencies with Result CSFRs (No Stall)**

| Stage          | $T_n$                 | $T_{n+1}$                   | $T_{n+2}$                   | $T_{n+3}$                   | $T_{n+4}^1)$                | $T_{n+5}$                   |
|----------------|-----------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|
| <b>DECODE</b>  | $I_n = MUL$<br>R0, R1 | $I_{n+1} = MOV$<br>R3, [R0] | $I_{n+2} = MOV$<br>R6, MDL  | $I_{n+3} = ADD$<br>R6, R1   | $I_{n+4}$                   | $I_{n+5}$                   |
| <b>ADDRESS</b> | $I_{n-1}$             | $I_n = MUL$<br>R0, R1       | $I_{n+1} = MOV$<br>R3, [R0] | $I_{n+2} = MOV$<br>R6, MDL  | $I_{n+3} = ADD$<br>R6, R1   | $I_{n+4}$                   |
| <b>MEMORY</b>  | $I_{n-2}$             | $I_{n-1}$                   | $I_n = MUL$<br>R0, R1       | $I_{n+1} = MOV$<br>R3, [R0] | $I_{n+2} = MOV$<br>R6, MDL  | $I_{n+3} = ADD$<br>R6, R1   |
| <b>EXECUTE</b> | $I_{n-3}$             | $I_{n-2}$                   | $I_{n-1}$                   | $I_n = MUL$<br>R0, R1       | $I_{n+1} = MOV$<br>R3, [R0] | $I_{n+2} = MOV$<br>R6, MDL  |
| <b>WR.BACK</b> | $I_{n-4}$             | $I_{n-3}$                   | $I_{n-2}$                   | $I_{n-1}$                   | $I_n = MUL$<br>R0, R1       | $I_{n+1} = MOV$<br>R3, [R0] |

1) MDL can be read now, no stall cycle necessary.

## Central Processing Unit (CPU)

### CSFRs Affecting the Whole CPU

Some CSFRs affect the whole CPU or the pipeline before the Memory stage. The CPU-SFRs CPUCON1/2, CP, SP, STKUN, STKOV, VECSEG, TFR, and PSW affect the overall CPU function, while the CPU-SFRs IDX0, IDX1, QX1, QX0, DPP0, DPP1, DPP2, and DPP3 only affect the DECODE, ADDRESS, and MEMORY stage when they are modified **explicitly**. In this case the pipeline behavior depends on the instruction and addressing mode used to modify the CSFR.

In the case of modification of these CSFRs by “POP CSFR” or by instructions using the reg,#data16 addressing mode, a special mechanism is implemented to improve performance during the initialization.

For further explanation, the instruction which modifies the CSFR can be called “instruction\_modify\_CSFR”. This special case is detected in the DECODE stage when the instruction\_modify\_CSFR enters the processing pipeline. Further on, instructions described in the following list are held in the DECODE stage (all other instructions are not held):

- Instructions using long addressing mode (mem)
- Instructions using indirect addressing modes ([R<sub>w</sub>], [R<sub>w</sub>+]...), except JMPI and CALLI
- ENWDT, DISWDT, EINIT
- All CoXXX instructions

If the CPUCON1/2, CP, SP, STKUN, STKOV, VECSEG, TFR, or the PSW are modified and the instruction\_modify\_CSFR reaches the EXECUTE stage, the pipeline is canceled. The modification affects the entire pipeline and the instruction prefetch. A clean cancel and restart mechanism is required to guarantee a correct instruction flow. In case of modification of IDX0, IDX1, QX1, QX0, DPP0, DPP1, DPP2, or DPP3 only the DECODE, ADDRESS, and MEMORY stages are affected and the pipeline needs not to be canceled. The modification does not affect the instructions in the ADDRESS, MEMORY stage because they are not using this resource. Other kinds of instructions are held in the DECODE stage until the CSFR is modified.

The following example shows a case in which the pipeline is stalled. The instruction “MOV R6, R1” after the “MOV IDX1, #12” instruction which modifies the CSFR will be held in DECODE Stage until the IDX1 register is updated. The next example shows an optimized initialization routine.

Conflict\_Canceling:

|                  |               |
|------------------|---------------|
| I <sub>n</sub>   | MOV IDX1, #12 |
| I <sub>n+1</sub> | MOV R6, mem   |
| I <sub>n+2</sub> | ADD R6, R1    |
| I <sub>n+3</sub> | MOV R3, [R0]  |

## Central Processing Unit (CPU)

**Table 5-11 Pipeline Dependencies with Control CSFRs (Canceling)**

| <b>Stage</b>   | <b>T<sub>n</sub></b>              | <b>T<sub>n+1</sub></b>            | <b>T<sub>n+2</sub></b>            | <b>T<sub>n+3</sub></b>            | <b>T<sub>n+4</sub></b>            | <b>T<sub>n+5</sub></b>            |
|----------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------------|
| <b>DECODE</b>  | I <sub>n</sub> = MOV<br>IDX1, #12 | I <sub>n+1</sub> = MOV<br>R6, mem | I <sub>n+2</sub> = ADD<br>R6, R1  |
| <b>ADDRESS</b> | I <sub>n-1</sub>                  | I <sub>n</sub> = MOV<br>IDX1, #12 | —                                 | —                                 | —                                 | I <sub>n+1</sub> = MOV<br>R6, mem |
| <b>MEMORY</b>  | I <sub>n-2</sub>                  | I <sub>n-1</sub>                  | I <sub>n</sub> = MOV<br>IDX1, #12 | —                                 | —                                 | —                                 |
| <b>EXECUTE</b> | I <sub>n-3</sub>                  | I <sub>n-2</sub>                  | I <sub>n-1</sub>                  | I <sub>n</sub> = MOV<br>IDX1, #12 | —                                 | —                                 |
| <b>WR.BACK</b> | I <sub>n-4</sub>                  | I <sub>n-3</sub>                  | I <sub>n-2</sub>                  | I <sub>n-1</sub>                  | I <sub>n</sub> = MOV<br>IDX1, #12 | —                                 |

Conflict\_Canceling\_Optimized:

I<sub>n</sub>      MOV IDX1, #12  
 I<sub>n+1</sub>    MOV MAH, #23  
 I<sub>n+2</sub>    MOV MAL, #25  
 I<sub>n+3</sub>    MOV R3, #08

**Table 5-12 Pipeline Dependencies with Control CSFRs (Optimized)**

| <b>Stage</b>   | <b>T<sub>n</sub></b>              | <b>T<sub>n+1</sub></b>             | <b>T<sub>n+2</sub></b>             | <b>T<sub>n+3</sub></b>             | <b>T<sub>n+4</sub></b>             | <b>T<sub>n+5</sub></b>             |
|----------------|-----------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|
| <b>DECODE</b>  | I <sub>n</sub> = MOV<br>IDX1, #12 | I <sub>n+1</sub> = MOV<br>MAH, #23 | I <sub>n+2</sub> = MOV<br>MAL, #25 | I <sub>n+3</sub> = MOV<br>R3, #08  | I <sub>n+4</sub>                   | I <sub>n+5</sub>                   |
| <b>ADDRESS</b> | I <sub>n-1</sub>                  | I <sub>n</sub> = MOV<br>IDX1, #12  | I <sub>n+1</sub> = MOV<br>MAH, #23 | I <sub>n+2</sub> = MOV<br>MAL, #25 | I <sub>n+3</sub> = MOV<br>R3, #08  | I <sub>n+4</sub>                   |
| <b>MEMORY</b>  | I <sub>n-2</sub>                  | I <sub>n-1</sub>                   | I <sub>n</sub> = MOV<br>IDX1, #12  | I <sub>n+1</sub> = MOV<br>MAH, #23 | I <sub>n+2</sub> = MOV<br>MAL, #25 | I <sub>n+3</sub> = MOV<br>R3, #08  |
| <b>EXECUTE</b> | I <sub>n-3</sub>                  | I <sub>n-2</sub>                   | I <sub>n-1</sub>                   | I <sub>n</sub> = MOV<br>IDX1, #12  | I <sub>n+1</sub> = MOV<br>MAH, #23 | I <sub>n+2</sub> = MOV<br>MAL, #25 |
| <b>WR.BACK</b> | I <sub>n-4</sub>                  | I <sub>n-3</sub>                   | I <sub>n-2</sub>                   | I <sub>n-1</sub>                   | I <sub>n</sub> = MOV<br>IDX1, #12  | I <sub>n+1</sub> = MOV<br>MAH, #23 |

For all the other instructions that modify this kind of CSFR, a simple stall and cancel mechanism guarantees the correct instruction flow.

A possible explicit write-operation to this kind of CSFRs is detected on the MEMORY stage of the pipeline. The following instructions on the ADDRESS and DECODE Stage are stalled. If the instruction reaches the EXECUTE stage, the entire pipeline and the Instruction FIFO of the IFU are canceled. The instruction flow is completely re-started.

## Central Processing Unit (CPU)

Conflict\_Canceling\_Completely:

$I_n \quad \text{MOV PSW}, R4$

$I_{n+1} \quad \text{MOV R6}, R1$

$I_{n+2} \quad \text{ADD R6}, R1$

$I_{n+3} \quad \text{MOV R3}, [R0]$

**Table 5-13 Pipeline Dependencies with Control CSFRs (Cancel All)**

| Stage          | $T_{n+1}$                     | $T_{n+2}$                     | $T_{n+3}$                     | $T_{n+4}$                  | $T_{n+5}$ | $T_{n+6}$                     |
|----------------|-------------------------------|-------------------------------|-------------------------------|----------------------------|-----------|-------------------------------|
| <b>DECODE</b>  | $I_{n+1} = \text{MOV R6}, R1$ | $I_{n+2} = \text{ADD R6}, R1$ | $I_{n+2} = \text{ADD R6}, R1$ | —                          | —         | $I_{n+1} = \text{MOV R6}, R1$ |
| <b>ADDRESS</b> | $I_n = \text{MOV PSW}, R4$    | $I_{n+1} = \text{MOV R6}, R1$ | $I_{n+1} = \text{MOV R6}, R1$ | —                          | —         | —                             |
| <b>MEMORY</b>  | $I_{n-1}$                     | $I_n = \text{MOV PSW}, R4$    | —                             | —                          | —         | —                             |
| <b>EXECUTE</b> | $I_{n-2}$                     | $I_{n-1}$                     | $I_n = \text{MOV PSW}, R4$    | —                          | —         | —                             |
| <b>WR.BACK</b> | $I_{n-3}$                     | $I_{n-2}$                     | $I_{n-1}$                     | $I_n = \text{MOV PSW}, R4$ | —         | —                             |

## Central Processing Unit (CPU)

## 5.4 CPU Configuration Registers

The CPU configuration registers select a number of general features and behaviors of the XC27x5X's CPU core. In general these registers are only written by the startup software and not altered during application software run time.

*Note: The CPU configuration registers are protected by the register security mechanism after the EINIT instruction has been executed.*

### CPUCON1

#### CPU Control Register 1

 SFR (FE18<sub>H</sub>/0C<sub>H</sub>)

 Reset Value: 0007<sub>H</sub>

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5     | 4       | 3       | 2        | 1  | 0   |
|----|----|----|----|----|----|---|---|---|---|-------|---------|---------|----------|----|-----|
|    |    |    |    |    |    | 0 |   |   |   | VECSC | WDT CTL | SGT DIS | INTS CXT | BP | ZCJ |

Bit descriptions: r = read-only, rw = read/write

| Field   | Bits   | Type | Description                                                                                                                                                                                                                                                                          |
|---------|--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0       | [15:7] | r    | <b>Reserved</b><br>Read as 0, should be written 0                                                                                                                                                                                                                                    |
| VECSC   | [6:5]  | rw   | <b>Scaling Factor of Vector Table</b><br>00 <sub>B</sub> Space between two vectors is 2 words <sup>1)</sup><br>01 <sub>B</sub> Space between two vectors is 4 words<br>10 <sub>B</sub> Space between two vectors is 8 words<br>11 <sub>B</sub> Space between two vectors is 16 words |
| WDTCTL  | 4      | rw   | <b>Configuration of Watchdog Timer</b><br>0 <sub>B</sub> DISWDT executable only until End Of Init <sup>2)</sup><br>1 <sub>B</sub> DISWDT/ENWDT always executable<br>(enhanced WDT mode)                                                                                              |
| SGTDIS  | 3      | rw   | <b>Segmentation Disable/Enable Control</b><br>0 <sub>B</sub> Segmentation enabled<br>1 <sub>B</sub> Segmentation disabled                                                                                                                                                            |
| INTSCXT | 2      | rw   | <b>Enable Interruptibility of Switch Context</b><br>0 <sub>B</sub> Switch context is not interruptible<br>1 <sub>B</sub> Switch context is interruptible                                                                                                                             |
| BP      | 1      | rw   | <b>Enable Branch Prediction Unit</b><br>0 <sub>B</sub> Branch prediction disabled<br>1 <sub>B</sub> Branch prediction enabled                                                                                                                                                        |
| ZCJ     | 0      | rw   | <b>Enable Zero-Cycle Jump Function</b><br>0 <sub>B</sub> Zero-cycle jump function disabled<br>1 <sub>B</sub> Zero-cycle jump function enabled                                                                                                                                        |

## Central Processing Unit (CPU)

- 1) The default value (2 words) is compatible with the vector distance defined in the C166 Family architecture.
- 2) The DISWDT (executed after EINIT) and ENWDT instructions are internally converted in a NOP instruction.

**CPUCON2**
**CPU Control Register 2**
**SFR (FE1A<sub>H</sub>/0D<sub>H</sub>)**
**Reset Value: 8FBB<sub>H</sub>**

| 15 | 14 | 13 | 12 | 11 | 10 | 9                | 8              | 7                 | 6                | 5        | 4                | 3           | 2                 | 1                 | 0                  |          |           |
|----|----|----|----|----|----|------------------|----------------|-------------------|------------------|----------|------------------|-------------|-------------------|-------------------|--------------------|----------|-----------|
|    |    |    |    |    |    | <b>FIFODEPTH</b> | <b>FIFOFED</b> | <b>BYP<br/>PF</b> | <b>BYP<br/>F</b> | <b>1</b> | <b>STE<br/>N</b> | <b>LFIC</b> | <b>OV<br/>RUN</b> | <b>RET<br/>ST</b> | <b>FAS<br/>TBL</b> | <b>1</b> | <b>SL</b> |
| rw |    |    |    | rw |    | rw               | rw             | r                 | rw               | rw       | rw               | rw          | rw                | r                 | rw                 |          |           |

| Field            | Bits    | Type | Description                                                                                                                                                                                                                                                                   |
|------------------|---------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>FIFODEPTH</b> | [15:12] | rw   | <b>FIFO Depth Configuration</b><br>0 <sub>H</sub> No FIFO (entries)<br>1 <sub>H</sub> One FIFO entry<br>...<br>8 <sub>H</sub> Eight FIFO entries<br>9 <sub>H</sub> reserved<br>...<br>F <sub>H</sub> reserved                                                                 |
| <b>FIFOFED</b>   | [11:10] | rw   | <b>FIFO Fed Configuration</b><br>00 <sub>B</sub> FIFO disabled<br>01 <sub>B</sub> FIFO filled with up to one instruction per cycle<br>10 <sub>B</sub> FIFO filled with up to two instructions per cycle<br>11 <sub>B</sub> FIFO filled with up to three instruction per cycle |
| <b>BYPPF</b>     | 9       | rw   | <b>Prefetch Bypass Control</b><br>0 <sub>B</sub> Bypass path from prefetch to decode disabled<br>1 <sub>B</sub> Bypass path from prefetch to decode available                                                                                                                 |
| <b>BYPF</b>      | 8       | rw   | <b>Fetch Bypass Control</b><br>0 <sub>B</sub> Bypass path from fetch to decode disabled<br>1 <sub>B</sub> Bypass path from fetch to decode available                                                                                                                          |
| <b>1</b>         | 7       | r    | <b>Reserved</b><br>Read as 1, should be written 1                                                                                                                                                                                                                             |
| <b>STEN</b>      | 6       | rw   | <b>Stall Instruction Enable</b> (for debug purposes)<br>0 <sub>B</sub> Stall Instruction disabled<br>1 <sub>B</sub> Stall Instruction enabled (see example below)                                                                                                             |
| <b>LFIC</b>      | 5       | rw   | <b>Linear Follower Instruction Cache</b><br>0 <sub>B</sub> Linear Follower Instruction Cache disabled<br>1 <sub>B</sub> Linear Follower Instruction Cache enabled                                                                                                             |

## Central Processing Unit (CPU)

| Field         | Bits | Type | Description                                                                                                               |
|---------------|------|------|---------------------------------------------------------------------------------------------------------------------------|
| <b>OVRUN</b>  | 4    | rw   | <b>Pipeline Control</b><br>$0_B$ Overrun of pipeline bubbles not allowed<br>$1_B$ Overrun of pipeline bubbles allowed     |
| <b>RETST</b>  | 3    | rw   | <b>Enable Return Stack</b><br>$0_B$ Return Stack is disabled<br>$1_B$ Return Stack is enabled                             |
| <b>FASTBL</b> | 2    | rw   | <b>Enables the fast injection of block transfers</b><br>$0_B$ Direct injection disabled<br>$1_B$ Direct injection enabled |
| <b>1</b>      | 1    | r    | <b>Reserved</b><br>Read as 1, should be written 1                                                                         |
| <b>SL</b>     | 0    | rw   | <b>Enables Short Loop Mode</b><br>$0_B$ Short loop mode disabled<br>$1_B$ Short loop mode enabled                         |

*Note: This register must only be modified when explicitly documented - e.g. in an errata sheet.*

## Central Processing Unit (CPU)

## 5.5 Use of General Purpose Registers

The CPU provides three banks of sixteen dedicated registers R0, R1, R2, ... R15, called General Purpose Registers (GPRs), which can be accessed in one CPU cycle. The GPRs are the working registers of the arithmetic and logic units and many also serve as address pointers for indirect addressing modes.

The register banks are accessed via the 5-port register file providing the high access speed required for the CPU's performance. The register file is split into three independent physical register banks. There are **two types of register banks**:

- **Two local register banks** which are a part of the register file
- **One global register bank** which is memory-mapped and cached in the register file



**Figure 5-3 Register File**

Bitfield BANK in register PSW selects which of the three physical register banks is activated. The selected bank can be changed explicitly by any instruction which writes to the PSW, or implicitly by a RETI instruction, an interrupt or hardware trap. In case of an interrupt, the selection of the register bank is configured via registers BNKSELx in the Interrupt Controller ITC. Hardware traps always use the global register bank.

**Central Processing Unit (CPU)**

The local register banks are built of dedicated physical registers, while the global register bank represents a cache. Multiple global banks can be mapped to the internal DPRAM. Each of these banks uses a block of 16 consecutive words. A Context Pointer (CP) register determines the base address of the current selected bank. To provide the required access speed, the GPRs located in the DPRAM are cached in the 5-port register file (only one memory-mapped GPR bank can be cached at the time). If the global register bank is activated, the cache will be validated before further instructions are executed. After validation, all further accesses to the GPRs are redirected to the global register bank.


**Figure 5-4 Register Bank Selection via Register CP**

### 5.5.1 GPR Addressing Modes

Because the GPRs are the working registers and are accessed frequently, there are three possible ways to access a register bank:

- **Short GPR Address** (mnemonic: Rw or Rb)
- **Short Register Address** (mnemonic: reg or bitoff)
- **Long Memory Address** (mnemonic: mem), for the global bank only

**Short GPR Addresses** specify the register offset within the current register bank (selected via bitfield BANK). Short 4-bit GPR addresses can access all sixteen registers, short 2-bit addresses (used by some instructions) can access the lower four registers.

Depending on whether a register word (Rw) or byte (Rb) address is specified, the short GPR address is either multiplied by two (Rw) or not (Rb) before it is used to physically access the register bank. Thus, both byte and word GPR accesses are possible in this way.

*Note: GPRs used as indirect address pointers are always accessed wordwise.*

For the local register banks the resulting offset is used directly, for the global register bank the resulting offset is logically added to the contents of register CP which points to the memory location of the base of the current global register bank (see [Figure 5-5](#)).

**Short 8-Bit Register Addresses** within a range from F0<sub>H</sub> to FF<sub>H</sub> interpret the four least significant bits as short 4-bit GPR addresses, while the four most significant bits are ignored. The respective physical GPR address is calculated in the same way as for short 4-bit GPR addresses. For single bit GPR accesses, the GPR's word address is calculated in the same way. The accessed bit position within the word is specified by a separate additional 4-bit value.



**Figure 5-5 Implicit CP Use by Logical Short GPR Addressing Modes**

## Central Processing Unit (CPU)

**24-Bit Memory Addresses** can be directly used to access GPRs located in the DPRAM (not applicable for local register banks). In case of a memory read access, a hit detection logic checks if the accessed memory location is cached in the global register bank. In case of a cache hit the read is redirected to the global register bank. The data that is read from cache will be used and the read from memory will be discarded. This leads to a delay of one CPU cycle (MOV R4, mem [CP ≤ mem ≤ CP + 31]). In case of a memory write access, the hit detection logic determines a cache hit in advance. Nevertheless, the address conversion needs one additional CPU cycle. The value is directly written into the global register bank without further delay (MOV mem, R4).

*Note: The 24-bit GPR addressing mode requires an extra cycle for the read and write access.*

**Table 5-14 Addressing Modes to Access GPRs**

| Word Registers <sup>1)</sup> |                          | Byte Registers |                          | Short Address <sup>2)</sup> |                |                |
|------------------------------|--------------------------|----------------|--------------------------|-----------------------------|----------------|----------------|
| Name                         | Mem. Addr. <sup>3)</sup> | Name           | Mem. Addr. <sup>3)</sup> | 8-Bit                       | 4-Bit          | 2-Bit          |
| R0                           | (CP) + 0                 | RL0            | (CP) + 0                 | F0 <sub>H</sub>             | 0 <sub>H</sub> | 0 <sub>H</sub> |
| R1                           | (CP) + 2                 | RH0            | (CP) + 1                 | F1 <sub>H</sub>             | 1 <sub>H</sub> | 1 <sub>H</sub> |
| R2                           | (CP) + 4                 | RL1            | (CP) + 2                 | F2 <sub>H</sub>             | 2 <sub>H</sub> | 2 <sub>H</sub> |
| R3                           | (CP) + 6                 | RH1            | (CP) + 3                 | F3 <sub>H</sub>             | 3 <sub>H</sub> | 3 <sub>H</sub> |
| R4                           | (CP) + 8                 | RL2            | (CP) + 4                 | F4 <sub>H</sub>             | 4 <sub>H</sub> | ---            |
| R5                           | (CP) + 10                | RH2            | (CP) + 5                 | F5 <sub>H</sub>             | 5 <sub>H</sub> | ---            |
| R6                           | (CP) + 12                | RL3            | (CP) + 6                 | F6 <sub>H</sub>             | 6 <sub>H</sub> | ---            |
| R7                           | (CP) + 14                | RH3            | (CP) + 7                 | F7 <sub>H</sub>             | 7 <sub>H</sub> | ---            |
| R8                           | (CP) + 16                | RL4            | (CP) + 8                 | F8 <sub>H</sub>             | 8 <sub>H</sub> | ---            |
| R9                           | (CP) + 18                | RH4            | (CP) + 9                 | F9 <sub>H</sub>             | 9 <sub>H</sub> | ---            |
| R10                          | (CP) + 20                | RL5            | (CP) + 10                | FA <sub>H</sub>             | A <sub>H</sub> | ---            |
| R11                          | (CP) + 22                | RH5            | (CP) + 11                | FB <sub>H</sub>             | B <sub>H</sub> | ---            |
| R12                          | (CP) + 24                | RL6            | (CP) + 12                | FC <sub>H</sub>             | C <sub>H</sub> | ---            |
| R13                          | (CP) + 26                | RH6            | (CP) + 13                | FD <sub>H</sub>             | D <sub>H</sub> | ---            |
| R14                          | (CP) + 28                | RL7            | (CP) + 14                | FE <sub>H</sub>             | E <sub>H</sub> | ---            |
| R15                          | (CP) + 30                | RH7            | (CP) + 15                | FF <sub>H</sub>             | F <sub>H</sub> | ---            |

1) The first 8 GPRs (R7 ... R0) may also be accessed bytewise. Writing to a GPR byte does not affect the other byte of the respective GPR.

2) Short addressing modes are usable for all register banks.

3) Long addressing mode only usable for the memory mapped global bank.

### 5.5.2 Context Switching

When a task scheduler of an operating system activates a new task or an interrupt service routine is called or terminated, the working context (i.e. the registers) of the left task must be saved and the working context of the new task must be restored. The CPU context can be changed in two ways:

- Switching the selected register bank
- Switching the context of the global register bank

#### Switching the Selected Physical Register Bank

By updating bitfield BANK in register PSW the active register bank is switched immediately. It is possible to switch between the current memory-mapped GPR bank cached in the global register bank ( $BANK = 00_B$ ), local register bank 1 ( $BANK = 10_B$ ), and local register bank 2 ( $BANK = 11_B$ ).

In case of an interrupt service, the bank switch can be automatically executed by updating bitfield BANK from registers BNKSELx in the interrupt controller. By executing a RETI instruction, bitfield BANK will automatically be restored and the context will be switched to the original register bank.

The switch between the three physical register banks of the register file can also be executed by writing to bitfield BANK. Because of pipeline dependencies an explicit change of register PSW must cancel the pipeline.



**Figure 5-6 Context Switch by Changing the Physical Register Bank**

After a switch to a local register bank, the new bank is immediately available. After switching to the global register bank, the cached memory-mapped GPRs must be valid before any further instructions can be executed. If the global register bank is not valid at this time (in case if the context switch process has been interrupted), the cache validation process is started automatically.

## Central Processing Unit (CPU)

### Switching the Context of the Global Register Bank

The contents of the global register bank are switched by changing the base address of the memory-mapped GPR bank. The base address is given by the contents of the Context Pointer (CP).

After the CP has been updated, a state machine starts to store the old contents of the global register bank and to load the new one. The store and load algorithm is executed in nineteen CPU cycles: the execution of the cache validation process takes sixteen cycles plus three cycles to stall an instruction execution to avoid pipeline conflicts upon the completion of the validation process. The context switch process has two phases:

- **Store phase:** The contents of the global register bank<sup>1)</sup> is stored back into the DPRAM by executing eight injected STORE instructions. After the last STORE instruction the contents of the global register bank are invalidated.
- **Load phase:** The global register bank is loaded with the new context by executing eight injected LOAD instructions. After the last LOAD instruction the contents of the global register bank are validated.

The code execution is stopped until the global register bank is valid again. A hardware interrupt can occur during the validation process. The way the validation process is completed depends on the type of register bank selected for this interrupt:

- If the interrupt also uses a global register bank the validation process is finished before executing the service routine (see [Figure 5-7](#)).
- If the interrupt uses a local register bank the validation process is interrupted and the service routine is executed immediately (see [Figure 5-8](#)). After switching back to the global register bank, the validation process is finished:
  - If the interrupt occurred during the store phase, the entire validation process is restarted from the very beginning.
  - If the interrupt occurred during the load phase, only the load phase is repeated.

If a local-bank interrupt routine (Task B in [Figure 5-9](#)) is again interrupted by a global-bank interrupt (Task C), the suspended validation process must be finished before code of Task C can be executed. This means that the validation process of Task A does not affect the interrupt latency of Task B but the latency of Task C.

*Note: If Task C would immediately interrupt Task A, the register bank validation process of Task A would be finished first. The worst case interrupt latency is identical in both cases (see [Figure 5-7](#) and [Figure 5-9](#)).*

1) During the store phase of the context switch the complete register bank is written to the DPRAM even if the application only uses a part of this register bank. A register bank must not be located above FDE0<sub>H</sub>, otherwise the store phase will overwrite SFRs (beginning at FE00<sub>H</sub>).

## **Central Processing Unit (CPU)**



**Figure 5-7 Validation Process Interrupted by Global-Bank Interrupt**



**Figure 5-8 Validation Process Interrupted by Local-Bank Interrupt**



**Figure 5-9** Validation Process Interrupted by Local- and Global-Bank Intr.

### 5.5.2.1 The Context Pointer (CP)

This non-bit-addressable register selects the current global register bank context. It can be updated via any instruction capable of modifying SFRs.

**CP**
**Context Pointer**
**SFR (FE10<sub>H</sub>/08<sub>H</sub>)**
**Reset Value: FC00<sub>H</sub>**

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

CP

rw

| Field | Bits              | Type | Description                                                                                                                                                                                                                                                                 |
|-------|-------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1     | 15, 14,<br>13, 12 | r    | <b>Fixed part of CP</b><br>Read as 1                                                                                                                                                                                                                                        |
| CP    | [11:1]            | rw   | <b>Modifiable part of CP</b><br>Specifies bits [11:1] of the 16-bit base address of the current global (memory-mapped) register bank.<br>When writing a value to register CP with bits CP[11:9] = 000 <sub>B</sub> , bits CP[11:10] are set to 11 <sub>B</sub> by hardware. |
| 0     | 0                 | r    | <b>Fixed part of CP</b><br>Read as 0                                                                                                                                                                                                                                        |

*Note: It is the user's responsibility to ensure that the physical GPR address specified via CP register plus short GPR address is always an internal DPRAM location. If this condition is not met, unexpected results may occur. Do not set CP below the internal DPRAM start address. Do not set CP above FDE0<sub>H</sub>, otherwise the store phase will overwrite SFRs (beginning at FE00<sub>H</sub>).*

The XC27x5X switches the complete memory-mapped GPR bank with a single instruction. After switching, the service routine executes within its own separate context.

The instruction "SCXT CP, #New\_Bank" pushes the value of the current context pointer (CP) into the system stack and loads CP with the immediate value "New\_Bank", which selects a new register bank. The service routine may now use its "own registers". This memory register bank is preserved when the service routine terminates, i.e. its contents are available on the next call.

Before returning from the service routine (RETI), the previous CP is simply popped from the system stack which returns the registers to the original bank.

*Note: Due to the internal instruction pipeline, a write operation to the CP register stalls the instruction flow until the register file context switch is really executed. The*

---

## Central Processing Unit (CPU)

*instruction immediately following the instruction that updates CP register can use the new value of the changed CP.*

## 5.6 Code Addressing

The XC27x5X provides a total addressable memory space of 16 Mbytes. This address space is arranged as 256 segments of 64 Kbytes each. A dedicated 24-bit code address pointer is used to access the memories for instruction fetches. This pointer has two parts: an 8-bit code segment pointer CSP and a 16-bit offset pointer called Instruction Pointer (IP). The concatenation of the CSP and IP results directly in a correct 24-bit physical memory address.



**Figure 5-10 Addressing via the Code Segment and Instruction Pointer**

**The Code Segment Pointer CSP** selects the code segment being used at run-time to access instructions. The lower 8 bits of register CSP select one of up 256 segments of 64 Kbytes each, while the higher 8 bits are reserved for future use. The hardware reset value is 0000<sub>H</sub>, but immediately after reset it is loaded with the contents of the VECSEG register due to an injected MOVCSIP instruction.

*Note: Register CSP can only be read but cannot be written by data operations.*

**In segmented memory mode** (default after reset), register CSP is modified either directly by JMP\$ and CALL\$ instructions, or indirectly via the stack by RET\$ and RETI\$ instructions.

**In non-segmented memory mode** (selected by setting bit SGTDIS in register CPUCON1), CSP is fixed to the segment of the instruction that disabled segmentation. Modification by inter-segment CALLs or RETurns is no longer possible.

## Central Processing Unit (CPU)

For processing an accepted interrupt or a TRAP, register CSP is automatically loaded with the segment of the vector table (defined in register VECSEG).

*Note: For the correct execution of interrupt tasks in non-segmented memory mode, the contents of VECSEG must select the same segment as the current value of CSP, i.e. the vector table must be located in the segment pointed to by the CSP.*

**CSP**


| Field | Bits   | Type | Description                                                                                              |
|-------|--------|------|----------------------------------------------------------------------------------------------------------|
| 0     | [15:8] | r    | <b>Reserved</b><br>Read as 0, should be written 0                                                        |
| SEGNR | [7:0]  | rh   | <b>Segment Number</b><br>Specifies the code segment from which the current instruction is to be fetched. |

*Note: After a reset, register CSP is automatically loaded from register VECSEG.*

**The Instruction Pointer IP** determines the 16-bit intra-segment address of the currently fetched instruction within the code segment selected by the CSP register. Register IP is not mapped into the XC27x5X's address space; thus, it is not directly accessible by the programmer. However, the IP can be modified indirectly via the stack by means of a return instruction. IP is implicitly updated by the CPU for branch instructions and after instruction fetch operations.

**IP**


## Central Processing Unit (CPU)

| Field     | Bits   | Type | Description                                                                                                                                                                    |
|-----------|--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>IP</b> | [15:1] | h    | <b>Instruction Pointer</b><br>Specifies bits [15:1] of the intra segment offset from which the current instruction is to be fetched. IP refers to the current segment <SEGNR>. |
| <b>0</b>  | 0      | r    | <b>Fixed part of IP</b><br>Read as 0                                                                                                                                           |

## 5.7 Data Addressing

The Address Data Unit (ADU) contains two independent arithmetic units to generate, calculate, and update addresses for data accesses, the Standard Address Generation Unit (SAGU) and the DSP Address Generation Unit (DAGU). The ADU performs the following major tasks:

- Standard Address Generation (SAGU)
- DSP Address Generation (DAGU)
- Data Paging (SAGU)
- Stack Handling (SAGU)

The SAGU supports linear arithmetic for the indirect addressing modes and also generates the address in case of all other short and long addressing modes.

The DAGU contains an additional set of address pointers and offset registers which are used in conjunction with the CoXXX instructions only.

The CPU provides a lot of powerful addressing modes (short, long, indirect) for word, byte, and bit data accesses. The different addressing modes use different formats and have different scopes.

### 5.7.1 Short Addressing Modes

Short addressing modes allow access to the GPR, SFR or bit-addressable memory space. All of these addressing modes use an offset (8/4/2 bits) together with an implicit base address to specify a 24-bit physical address:

**Table 5-15 Short Addressing Modes**

| Mnemonic | Base Address <sup>1)</sup> | Offset                                 | Short Address Range | Scope of Access        |
|----------|----------------------------|----------------------------------------|---------------------|------------------------|
| Rw       | (CP)                       | $2 \times \text{Rw}$                   | 0 ... 15            | GPRs (word)            |
| Rb       | (CP)                       | $1 \times \text{Rb}$                   | 0 ... 15            | GPRs (byte)            |
| reg      | $00'FE00_H$                | $2 \times \text{reg}$                  | $00_H \dots EF_H$   | SFRs (word, low byte)  |
|          | $00'F000_H$                | $2 \times \text{reg}$                  | $00_H \dots EF_H$   | ESFRs (word, low byte) |
|          | (CP)                       | $2 \times (\text{reg} \wedge 0F_H)$    | $F0_H \dots FF_H$   | GPRs (word)            |
|          | (CP)                       | $1 \times (\text{reg} \wedge 0F_H)$    | $F0_H \dots FF_H$   | GPRs (bytes)           |
| bitoff   | $00'FD00_H$                | $2 \times \text{bitoff}$               | $00_H \dots 7F_H$   | RAM Bit word offset    |
|          | $00'FF00_H$                | $2 \times (\text{bitoff} \wedge 7F_H)$ | $80_H \dots EF_H$   | SFR Bit word offset    |
|          | $00'F100_H$                | $2 \times (\text{bitoff} \wedge 7F_H)$ | $80_H \dots EF_H$   | ESFR Bit word offset   |
|          | (CP)                       | $2 \times (\text{bitoff} \wedge 0F_H)$ | $F0_H \dots FF_H$   | GPR Bit word offset    |
| bitaddr  | Bit word<br>see bitoff     | Immediate bit position                 | 0 ... 15            | Any single bit         |

1) Accesses to general purpose registers (GPRs) may also access local register banks, instead of using CP.

## Central Processing Unit (CPU)

**Physical Address = Base Address +  $\Delta \times$  Short Address**

*Note:  $\Delta$  is 1 for byte GPRs,  $\Delta$  is 2 for word GPRs.*

**Rw, Rb:** Specifies direct access to any GPR in the currently active context (global register bank or local register bank). Both 'Rw' and 'Rb' require four bits in the instruction format. The base address of the global register bank is determined by the contents of register CP. 'Rw' specifies a 4-bit word GPR address, 'Rb' specifies a 4-bit byte GPR address within a local register bank or relative to (CP).

**reg:** Specifies direct access to any (E)SFR or GPR in the currently active context (global or local register bank). The 'reg' value requires eight bits in the instruction format. Short 'reg' addresses in the range from  $00_H$  to  $EF_H$  always specify (E)SFRs. In that case, the factor ' $\Delta$ ' equates 2 and the base address is  $00'FE00_H$  for the standard SFR area or  $00'F000_H$  for the extended ESFR area. The 'reg' accesses to the ESFR area require a preceding EXT\*R instruction to switch the base address. Depending on the opcode, either the total word (for word operations) or the low byte (for byte operations) of an SFR can be addressed via 'reg'. Note that the high byte of an SFR cannot be accessed via the 'reg' addressing mode. Short 'reg' addresses in the range from  $F0_H$  to  $FF_H$  always specify GPRs. In that case, only the lower four bits of 'reg' are significant for physical address generation and, therefore, it is identical to the address generation described for the 'Rb' and 'Rw' addressing modes.

**bitoff:** Specifies direct access to any word in the bit addressable memory space. The 'bitoff' value requires eight bits in the instruction format. The specified 'bitoff' range selects different base addresses to generate physical addresses (see **Table 5-15**). The 'bitoff' accesses to the ESFR area require a preceding EXT\*R instruction to switch the base address.

**bitaddr:** Any bit address is specified by a word address within the bit addressable memory space (see 'bitoff') and a bit position ('bitpos') within that word. Therefore, 'bitaddr' requires twelve bits in the instruction format.

### 5.7.2 Long Addressing Modes

Long addressing modes specify 24-bit addresses and, therefore, can access any word or byte data within the entire address space. Long addresses can be specified in different ways to generate the full 24-bit address:

- Use one of the four Data Page Pointers (DPP registers):** The used 16-bit pointer selects a DPP with bits 15 ... 14, bits 13 ... 0 specify the 14-bit data page offset (see **Figure 5-11**).
- Select the used data page directly:** The data page is selected by a preceding EXTP(R) instruction, bits 13 ... 0 of the used 16-bit pointer specify the 14-bit data page offset.
- Select the used segment directly:** The segment is selected by a preceding EXTS(R) instruction, the used 16-bit pointer specifies the 16-bit segment offset.

*Note: Word accesses on odd byte addresses are not executed. A hardware trap will be triggered.*



Figure 5-11 Data Page Pointer Addressing

## Central Processing Unit (CPU)

### 5.7.2.1 Data Page Pointers DPP0, DPP1, DPP2, DPP3

These four non-bit-addressable registers select up to four different data pages to be active simultaneously at run-time. The lower 10 bits of each DPP register select one of the 1024 possible 16-Kbyte data pages; the upper 6 bits are reserved for future use.

**DPP0**

**Data Page Pointer 0**      **SFR (FE00<sub>H</sub>/00<sub>H</sub>)**      **Reset Value: 0000<sub>H</sub>**

**DPP1**

**Data Page Pointer 1**      **SFR (FE02<sub>H</sub>/01<sub>H</sub>)**      **Reset Value: 0001<sub>H</sub>**

**DPP2**

**Data Page Pointer 2**      **SFR (FE04<sub>H</sub>/02<sub>H</sub>)**      **Reset Value: 0002<sub>H</sub>**

**DPP3**

**Data Page Pointer 3**      **SFR (FE06<sub>H</sub>/03<sub>H</sub>)**      **Reset Value: 0003<sub>H</sub>**



| Field | Bits   | Type | Description                                                                   |
|-------|--------|------|-------------------------------------------------------------------------------|
| 0     | [15:8] | r    | <b>Reserved</b><br>Read as 0, should be written 0                             |
| PN    | [9:0]  | rw   | <b>Data Page Number of DPPx</b><br>Specifies the data page selected via DPPx. |

The DPP registers allow access to the entire memory space in pages of 16 Kbytes each. The DPP registers are implicitly used whenever data accesses to any memory location are made via indirect or direct long 16-bit addressing modes (except for override accesses via EXTended instructions and PEC data transfers). After reset, the Data Page Pointers are initialized in such a way that all indirect or direct long 16-bit addresses result in identical 18-bit addresses. This allows access to data pages 3 ... 0 within segment 0 as shown in [Figure 5-11](#). If the user does not want to use data paging, no further action is required.

Data paging is performed by concatenating the lower 14 bits of an indirect or direct long 16-bit address with the contents of the DPP register selected by the upper two bits of the 16-bit address. The contents of the selected DPP register specify one of the 1024 possible data pages. This data page base address together with the 14-bit page offset forms the physical 24-bit address (even if segmentation is disabled).

A DPP register can be updated via any instruction capable of modifying an SFR.

## Central Processing Unit (CPU)

*Note: Due to the internal instruction pipeline, a write operation to the DPP<sub>x</sub> registers could stall the instruction flow until the DPP is actually updated. The instruction that immediately follows the instruction which updates the DPP register can use the new value of the changed DPP<sub>x</sub>.*



**Figure 5-12 Overriding the DPP Mechanism**

*Note: The overriding page or segment may be specified as a constant (#pag, #seg) or via a word GPR (Rw).*

**Table 5-16 Long Addressing Modes**

| Mnemonic | Base Address <sup>1)</sup> | Offset                         | Scope of Access  |
|----------|----------------------------|--------------------------------|------------------|
| mem      | (DPP <sub>x</sub> )        | mem $\wedge$ 3FFF <sub>H</sub> | Any Word or Byte |
| mem      | pag                        | mem $\wedge$ 3FFF <sub>H</sub> | Any Word or Byte |
| mem      | seg                        | mem                            | Any Word or Byte |

1) Represents either a 10-bit data page number to be concatenated with a 14-bit offset, or an 8-bit segment number to be concatenated with a 16-bit offset.

### 5.7.3 Indirect Addressing Modes

Indirect addressing modes can be considered as a combination of short and long addressing modes. This means that the “long” 16-bit pointer is provided indirectly by the contents of a word GPR which itself is specified directly by a short 4-bit address ('Rw' = 0 ... 15).

There are indirect addressing modes, which add a constant value to the GPR contents before the long 16-bit address is calculated. Other indirect addressing modes can decrement or increment the indirect address pointers (GPR contents) by 2 or 1 (referring to words or bytes) or by the contents of the offset registers QR0 or QR1.

**Table 5-17 Generating Physical Addresses from Indirect Pointers**

| Step | Executed Action                                                                                                                                                                              | Calculation                                                          | Notes                                                                            |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------------------------------|
| 1    | Calculate the address of the indirect pointer (word GPR) from its short address                                                                                                              | <b>GPR Address</b> =<br>$2 \times \text{Short Addr.}$<br>[+ (CP)]    | see <a href="#">Table 5-15</a>                                                   |
| 2    | Pre-decrement indirect pointer ('-Rw') depending on datatype ( $\Delta = 1$ or $2$ for byte or word operations)                                                                              | <b>(GPR Address)</b> =<br>$(\text{GPR Address})$<br>- $\Delta$       | Optional step, executed only if required by addressing mode                      |
| 3    | Adjust the pointer by a constant value ('Rw + const16')                                                                                                                                      | <b>Pointer</b> =<br>$(\text{GPR Address})$<br>+ Constant             | Optional step, executed only if required by addressing mode                      |
| 4    | Calculate the physical 24-bit address using the resulting pointer                                                                                                                            | <b>Physical Addr.</b> =<br>$\text{Page/Segment} +$<br>Pointer offset | Uses DPPs or page/segment override mechanisms,<br>see <a href="#">Table 5-16</a> |
| 5    | Post-in/decrement indirect pointer ('Rw $\pm$ ') depending on datatype ( $\Delta = 1$ or $2$ for byte or word operations), or depending on offset registers ( $\Delta = QRx$ ) <sup>1)</sup> | <b>(GPR Address)</b> =<br>$(\text{GPR Address})$<br>$\pm \Delta$     | Optional step, executed only if required by addressing mode                      |

1) Post-decrement and QRx-based modification is provided only for CoXXX instructions.

*Note:* Some instructions only use the lowest four word GPRs (R3 ... R0) as indirect address pointers, which are specified via short 2-bit addresses in that case.

The following indirect addressing modes are provided:

**Table 5-18 Indirect Addressing Modes**

| Mnemonic       | Particularities                                                                                                                           |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| [Rw]           | Most instructions accept any GPR (R15 ... R0) as indirect address pointer. Some instructions accept only the lower four GPRs (R3 ... R0). |
| [Rw+]          | The specified indirect address pointer is automatically post-incremented by 2 or 1 (for word or byte data operations) after the access.   |
| [-Rw]          | The specified indirect address pointer is automatically pre-decremented by 2 or 1 (for word or byte data operations) before the access.   |
| [Rw + #data16] | The specified 16-bit constant is added to the indirect address pointer, before the long address is calculated.                            |
| [Rw -]         | The specified indirect address pointer is automatically post-decremented by 2 (word data operations) after the access.                    |
| [Rw + QRx]     | The specified indirect address pointer is automatically post-incremented by QRx (word data operations) after the access.                  |
| [Rw - QRx]     | The specified indirect address pointer is automatically post-decremented by QRX (word data operations) after the access.                  |

### 5.7.3.1 Offset Registers QR0 and QR1

The non-bit-addressable offset registers QR0 and QR1 are used with CoXXX instructions. For possible instruction flow stalls refer to [Section 5.3.2.4](#).

**QR0**
**Offset Register**
**ESFR (F004<sub>H</sub>/02<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**
**QR1**
**Offset Register**
**ESFR (F006<sub>H</sub>/03<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**


| Field     | Bits   | Type | Description                                                                                                           |
|-----------|--------|------|-----------------------------------------------------------------------------------------------------------------------|
| <b>QR</b> | [15:1] | rw   | <b>Modifiable part of QRx</b><br>Specifies the 16-bit offset address for indirect addressing modes (LSB always zero). |
| <b>0</b>  | 0      | r    | <b>Fixed part of QRx</b><br>Read as 0                                                                                 |

### 5.7.4 DSP Addressing Modes

In addition to the Standard Address Generation Unit (SAGU), the DSP Address Generation Unit (DAGU) provides an additional set of pointer registers (IDX0, IDX1) and offset registers (QX0, QX1). The additional set of pointer registers IDX0 and IDX1 allows the execution of DSP specific CoXXX instructions in one CPU cycle. An independent arithmetic unit allows the update of these dedicated pointer registers in parallel with the GPR-pointer modification of the SAGU. The DAGU only supports indirect addressing modes that use the special pointer registers IDX0 and IDX1.

The address pointers can be used for arithmetic operations as well as for the special CoMOV instruction. The generation of the 24-bit memory address is different:

- For **CoMOV** instructions, the IDX pointers are concatenated with the DPPs or the selected page/segment address, as described for long addressing modes (see [Figure 5-11](#) for a summary).
- For **arithmetic CoXXX** instructions, the IDX pointers are automatically extended to a 24-bit memory address pointing to the internal DPRAM area, as shown in [Figure 5-13](#).

#### IDX0

**Address Pointer**

SFR (FF08<sub>H</sub>/84<sub>H</sub>)

**Reset Value:** 0000<sub>H</sub>

#### IDX1

**Address Pointer**

SFR (FF0A<sub>H</sub>/85<sub>H</sub>)

**Reset Value:** 0000<sub>H</sub>



| Field      | Bits   | Type | Description                                                            |
|------------|--------|------|------------------------------------------------------------------------|
| <b>IDX</b> | [15:1] | rw   | <b>Modifiable part of IDXx</b><br>Specifies the 16-bit address pointer |
| <b>0</b>   | 0      | r    | <b>Fixed part of IDXx</b><br>Read as 0                                 |

*Note: During the initialization of the IDX registers, instruction flow stalls are possible. For the proper operation, refer to [Section 5.3.2.4](#).*

## Central Processing Unit (CPU)

There are indirect addressing modes which allow parallel data move operations before the long 16-bit address is calculated (see [Figure 5-14](#) for an example). Other indirect addressing modes allow decrementing or incrementing the indirect address pointers (IDX<sub>x</sub> contents) by 2 or by the contents of the offset registers QX0 and QX1 (used in conjunction with the IDX pointers).

**QX0**
**Offset Register**
**ESFR (F000<sub>H</sub>/00<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**
**QX1**
**Offset Register**
**ESFR (F002<sub>H</sub>/01<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**


| Field     | Bits   | Type | Description                                                                                                |
|-----------|--------|------|------------------------------------------------------------------------------------------------------------|
| <b>QX</b> | [15:1] | rw   | <b>Modifiable part of QX<sub>x</sub></b><br>Specifies the 16-bit word offset for indirect addressing modes |
| <b>0</b>  | 0      | r    | <b>Fixed part of QX<sub>x</sub></b><br>Read as 0                                                           |

*Note: During the initialization of the QX registers, instruction flow stalls are possible. For the proper operation, refer to [Section 5.3.2.4](#).*


**Figure 5-13** Arithmetic MAC Operations and Addressing via the IDX Pointers

**Table 5-19** Generating Physical Addresses from Indirect Pointers (IDX<sub>x</sub>)

| Step | Executed Action                                                                                                                                                                                                    | Calculation                                                              | Notes                                                                              |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|------------------------------------------------------------------------------------|
| 1    | Determine the used IDX <sub>x</sub> pointer                                                                                                                                                                        | ---                                                                      | —                                                                                  |
| 2    | Calculate an intermediate long address for the parallel data move operation and in/decrement indirect pointer ('IDX <sub>x</sub> ±') by 2 ( $\Delta = 2$ ), or depending on offset registers ( $\Delta = Q_{xx}$ ) | <b>Interm. Addr. = (IDX<sub>x</sub> Address) <math>\pm \Delta</math></b> | Optional step, executed only if required by instruction CoXXXM and addressing mode |
| 3    | Calculate long 16-bit address                                                                                                                                                                                      | <b>Long Address = (IDX<sub>x</sub> Pointer)</b>                          | —                                                                                  |

## Central Processing Unit (CPU)

**Table 5-19 Generating Physical Addresses from Indirect Pointers (IDXx) (cont'd)**

| Step | Executed Action                                                                                                               | Calculation                                                  | Notes                                                                                                         |
|------|-------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| 4    | Calculate the physical 24-bit address using the resulting pointer                                                             | <b>Physical Addr. = Page/Segment + Pointer offset</b>        | Uses DPPs or page/segment override mechanisms, see <a href="#">Table 5-16</a> and <a href="#">Figure 5-13</a> |
| 5    | Post-in/decrement indirect pointer ('IDXx $\pm$ ') by 2 ( $\Delta = 2$ ), or depending on offset registers ( $\Delta = QXx$ ) | $(IDXx \text{ Pointer}) = (IDXx \text{ Pointer}) \pm \Delta$ | Optional step, executed only if required by addressing mode                                                   |

The following indirect addressing modes are provided:

**Table 5-20 DSP Addressing Modes**

| Mnemonic                | Particularities                                                                                                                                                                                                                                                                                                           |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [IDXx]                  | Most CoXXX instructions accept IDXx (IDX0, IDX1) as an indirect address pointer.                                                                                                                                                                                                                                          |
| [IDXx+]                 | The specified indirect address pointer is automatically post-incremented by 2 after the access.                                                                                                                                                                                                                           |
| with parallel data move | In case of a CoXXXM instruction, the address stored in the specified indirect address pointer is automatically pre-decremented by 2 for the parallel move operation. The pointer itself is not pre-decremented. Then, the specified indirect address pointer is automatically post-incremented by 2 after the access.     |
| [IDXx-]                 | The specified indirect address pointer is automatically post-decremented by 2 after the access.                                                                                                                                                                                                                           |
| with parallel data move | In case of a CoXXXM instruction, the address stored in the specified indirect address pointer is automatically pre-incremented by 2 for the parallel move operation. The pointer itself is not pre-incremented. Then, the specified indirect address pointer is automatically post-decremented by 2 after the access.     |
| [IDXx + QXx]            | The specified indirect address pointer is automatically post-incremented by QXx after the access.                                                                                                                                                                                                                         |
| with parallel data move | In case of a CoXXXM instruction, the address stored in the specified indirect address pointer is automatically pre-decremented by QXx for the parallel move operation. The pointer itself is not pre-decremented. Then, the specified indirect address pointer is automatically post-incremented by QXx after the access. |

**Table 5-20 DSP Addressing Modes (cont'd)**

| Mnemonic                              | Particularities                                                                                                                                                                                                                                                                                                                                   |
|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [IDX <sub>x</sub> - QX <sub>x</sub> ] | The specified indirect address pointer is automatically post-decremented by QX <sub>x</sub> after the access.                                                                                                                                                                                                                                     |
| with parallel data move               | In case of a CoXXXM instruction, the address stored in the specified indirect address pointer is automatically pre-incremented by QX <sub>x</sub> for the parallel move operation. The pointer itself is not pre-incremented. Then, the specified indirect address pointer is automatically post-decremented by QX <sub>x</sub> after the access. |

Note: An example for parallel data move operations can be found in [Figure 5-14](#).

### The CoREG Addressing Mode

The CoSTORE instruction utilizes the special CoREG addressing mode for immediate storage of the MAC-Unit register after a MAC operation. The address of the MAC-Unit register is coded in the CoSTORE instruction format as described in [Table 5-21](#):

**Table 5-21 Coding of the CoREG Addressing Mode**

| Mnemonic | Register                               | Coding of www:w bits [31:27] |
|----------|----------------------------------------|------------------------------|
| MSW      | MAC-Unit Status Word                   | 00000 <sub>B</sub>           |
| MAH      | MAC-Unit Accumulator High Word         | 00001 <sub>B</sub>           |
| MAS      | Limited MAC-Unit Accumulator High Word | 00010 <sub>B</sub>           |
| MAL      | MAC-Unit Accumulator Low Word          | 00100 <sub>B</sub>           |
| MCW      | MAC-Unit Control Word                  | 00101 <sub>B</sub>           |
| MRW      | MAC-Unit Repeat Word                   | 00110 <sub>B</sub>           |

The example in [Figure 5-14](#) shows the complex operation of CoXXXM instructions with a parallel move operation based on the descriptions about addressing modes given in [Section 5.7.3 \(Indirect Addressing Modes\)](#) and [Section 5.7.4 \(DSP Addressing Modes\)](#).

## Central Processing Unit (CPU)



Figure 5-14 Arithmetic MAC Operations with Parallel Move

## 5.7.5 The System Stack

The XC27x5X supports a system stack of up to 64 Kbytes. The stack can be located internally in one of the on-chip memories or externally. The 16-bit Stack Pointer register (SP) addresses the stack within a 64-Kbyte segment selected by the Stack Pointer Segment register (SPSEG). A virtual stack (usually bigger than 64 Kbytes) can be implemented by software. This mechanism is supported by the Stack Overflow register STKOV and the Stack Underflow register STKUN (see descriptions below).

### 5.7.5.1 The Stack Pointer Registers SP and SPSEG

Register SPSEG (not bit addressable) selects the segment being used at run-time to access the system stack. The lower eight bits of register SPSEG select one of up 256 segments of 64 Kbytes each, while the higher 8 bits are reserved for future use.

The Stack Pointer SP (not bit addressable) points to the top of the system stack (TOS). SP is pre-decremented whenever data is pushed onto the stack, and it is post-incremented whenever data is popped from the stack. Therefore, the system stack grows from higher towards lower memory locations.

System stack addresses are generated by directly extending the 16-bit contents of register SP by the contents of register SPSEG, as shown in [Figure 5-15](#).

The system stack cannot cross a 64-Kbyte segment boundary.



**Figure 5-15 Addressing via the Stack Pointer**

## Central Processing Unit (CPU)

**SP**
**Stack Pointer**
**SFR (FE12<sub>H</sub>/09<sub>H</sub>)**
**Reset Value: FC00<sub>H</sub>**

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

| Field     | Bits   | Type | Description                                                                                                    |
|-----------|--------|------|----------------------------------------------------------------------------------------------------------------|
| <b>SP</b> | [15:1] | rwh  | <b>Modifiable part of SP</b><br>Specifies bits [15:1] of the 16-bit system stack pointer intra segment address |
| <b>0</b>  | 0      | r    | <b>Fixed part of SP</b><br>Read as 0                                                                           |

**SPSEG**
**Stack Pointer Segment**
**SFR (FF0C<sub>H</sub>/86<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**

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

| Field          | Bits   | Type | Description                                                                              |
|----------------|--------|------|------------------------------------------------------------------------------------------|
| <b>0</b>       | [15:8] | r    | <b>Reserved</b><br>Read as 0, should be written 0                                        |
| <b>SPSEGNR</b> | [7:0]  | rw   | <b>Stack Pointer Segment Number</b><br>Specifies the segment where the stack is located. |

Note: *SPSEG and SP can be updated via any instruction capable of modifying a 16-bit SFR. Due to the internal instruction pipeline, a write operation to SPSEG or SP stalls the instruction flow until the register is really updated. The instruction immediately following the instruction updating SPSEG or SP can use the new value.*

## Central Processing Unit (CPU)

### 5.7.5.2 The Stack Overflow/Underflow Pointers STKOV/STKUN

These limit registers (not bit-addressable) supervise the stack pointer. A trap is generated when the stack pointer reaches its upper or lower limit. The Stack Pointer Segment Register SPSG is not taken into account for the stack pointer comparison. The system stack cannot cross a 64-Kbyte segment.

STKOV is compared with SP before each implicit write operation which decrements the contents of SP (instructions CALLA, CALLI, CALLR, CALLS, PCALL, TRAP, SCXT, or PUSH). If the contents of SP are equal to the contents of STKOV a stack overflow trap is triggered.

STKUN is compared with SP before each implicit read operation which increments the contents of SP (instructions RET, RETS, RETP, RETI, or POP). If the contents of SP are equal to the contents of STKUN a stack underflow trap is triggered.

The Stack Overflow/Underflow Traps may be used in two different ways:

- **Fatal error indication** treats the stack overflow as a system error and executes the associated trap service routine.  
In case of a stack overflow trap, data in the bottom of the stack may have been overwritten by the status information stacked upon servicing the trap itself.
- **Virtual stack control** allows the system stack to be used as a 'Stack Cache' for a bigger external user stack: flush cache in case of an overflow, refill cache in case of an underflow.

#### Scope of Stack Limit Control

The stack limit control implemented by the register pair STKOV and STKUN detects cases in which the Stack Pointer (SP) crosses the defined stack area as a result of an implicit change.

If the stack pointer was explicitly changed as a result of move or arithmetic instruction, SP is not compared to the contents of STKOV and STKUN. In this case, a stack violation will not be detected if the modified stack pointer is on or outside the defined limits, i.e. below (STKOV) or above (STKUN). Stack overflow/underflow is detected only in case of implicit SP modification.

SP may be operated outside the permitted SP range without triggering a trap. However, if SP reaches the limit of the permitted SP range from outside the range as a result of an implicit change (PUSH or POP, for example), the respective trap will be triggered.

*Note: STKOV and STKUN can be updated via any instruction capable of modifying an SFR. If a stack overflow or underflow event occurs in an ATOMIC/EXT sequence, the stack operations that are part of the sequence are completed. The trap is issued after the completion of the entire ATOMIC/EXT sequence.*

## Central Processing Unit (CPU)

**STKOV**
**Stack Overflow Pointer**
**SFR (FE14<sub>H</sub>/0A<sub>H</sub>)**
**Reset Value: FA00<sub>H</sub>**

|              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 15           | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| <b>STKOV</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0 |
| rw           |    |    |    |    |    |   |   |   |   |   |   |   |   |   | r |

| Field        | Bits   | Type | Description                                                                                                     |
|--------------|--------|------|-----------------------------------------------------------------------------------------------------------------|
| <b>STKOV</b> | [15:1] | rw   | <b>Modifiable part of STKOV</b><br>Specifies the segment offset address of the lower limit of the system stack. |
| <b>0</b>     | 0      | r    | <b>Fixed part of STKOV</b><br>Read as 0                                                                         |

**STKUN**
**Stack Underflow Pointer**
**SFR (FE16<sub>H</sub>/0B<sub>H</sub>)**
**Reset Value: FC00<sub>H</sub>**

|              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 15           | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| <b>STKUN</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0 |
| rw           |    |    |    |    |    |   |   |   |   |   |   |   |   |   | r |

| Field        | Bits   | Type | Description                                                                                                     |
|--------------|--------|------|-----------------------------------------------------------------------------------------------------------------|
| <b>STKUN</b> | [15:1] | rw   | <b>Modifiable part of STKUN</b><br>Specifies the segment offset address of the upper limit of the system stack. |
| <b>0</b>     | 0      | r    | <b>Fixed part of STKUN</b><br>Read as 0                                                                         |

## Central Processing Unit (CPU)

## 5.8 Standard Data Processing

All standard arithmetic, shift-, and logical operations are performed in the 16-bit ALU. In addition to the standard functions, the ALU of the XC27x5X includes a bit-manipulation unit and a multiply and divide unit. Most internal execution blocks have been optimized to perform operations on either 8-bit or 16-bit numbers. After the pipeline has been filled, most instructions are completed in one CPU cycle. The status flags are automatically updated in register PSW after each ALU operation and reflect the current state of the microcontroller. These flags allow branching upon specific conditions. Support of both signed and unsigned arithmetic is provided by the user selectable branch test. The status flags are also preserved automatically by the CPU upon entry into an interrupt or trap routine. Another group of bits represents the current CPU interrupt status. Two separate bits (USR0 and USR1) are provided as general purpose flags.

### PSW

#### Processor Status Word

#### SFR (FF10<sub>H</sub>/88<sub>H</sub>)

 Reset Value: 0000<sub>H</sub>

| 15  | 14 | 13 | 12 | 11  | 10                | 9    | 8        | 7        | 6   | 5   | 4   | 3   | 2   | 1   | 0 |
|-----|----|----|----|-----|-------------------|------|----------|----------|-----|-----|-----|-----|-----|-----|---|
|     |    |    |    | IEN | HLD<br>EN_<br>PL1 | BANK | USR<br>1 | USR<br>0 | PL0 | E   | Z   | V   | C   | N   |   |
| rwh |    |    |    | rw  | rwh               | rwh  | rwh      | rwh      | rwh | rwh | rwh | rwh | rwh | rwh |   |

| Field     | Bits    | Type | Description                                                                                                                                                                                                                                                                          |
|-----------|---------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ILVL      | [15:12] | rwh  | <b>CPU Priority Level</b><br>0 <sub>H</sub> Lowest Priority<br>...<br>F <sub>H</sub> Highest Priority                                                                                                                                                                                |
| IEN       | 11      | rw   | <b>Global Interrupt/PEC Enable Bit</b><br>0 <sub>B</sub> Interrupt/PEC requests are disabled<br>1 <sub>B</sub> Interrupt/PEC requests are enabled                                                                                                                                    |
| HLDEN_PL1 | 10      | rwh  | <b>Hold Enable/Protection Level selection 1</b><br>0 <sub>B</sub> external bus arbitration disabled or protection level 0/1 (refer to <a href="#">Table 5-23</a> )<br>1 <sub>B</sub> external bus arbitration enabled or protection level 2/3 (refer to <a href="#">Table 5-23</a> ) |
| BANK      | [9:8]   | rwh  | <b>Reserved for Register File Bank Selection</b><br>00 <sub>B</sub> Global register bank<br>01 <sub>B</sub> Reserved<br>10 <sub>B</sub> Local register bank 1<br>11 <sub>B</sub> Local register bank 2                                                                               |

## Central Processing Unit (CPU)

| Field       | Bits | Type | Description                                                                                                                                                                   |
|-------------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>USR1</b> | 7    | rwh  | <b>General Purpose Flag</b><br>Can be used by application software. Also set when using repeated MAC instructions ( <a href="#">Section 5.9.11</a> )                          |
| <b>USR0</b> | 6    | rwh  | <b>General Purpose Flag</b><br>Can be used by application software. Also set when using repeated MAC instructions ( <a href="#">Section 5.9.11</a> )                          |
| <b>PL0</b>  | 5    | rwh  | <b>Protection Level selection 0</b><br>$0_B$ Protection level 0/2 (refer to <a href="#">Table 5-23</a> )<br>$1_B$ Protection level 1/3 (refer to <a href="#">Table 5-23</a> ) |
| <b>E</b>    | 4    | rwh  | <b>End of Table Flag</b><br>$0_B$ Source operand is neither $8000_H$ nor $80_H$<br>$1_B$ Source operand is $8000_H$ or $80_H$                                                 |
| <b>Z</b>    | 3    | rwh  | <b>Zero Flag</b><br>$0_B$ ALU result is not zero<br>$1_B$ ALU result is zero                                                                                                  |
| <b>V</b>    | 2    | rwh  | <b>Overflow Flag</b><br>$0_B$ No Overflow produced<br>$1_B$ Overflow produced                                                                                                 |
| <b>C</b>    | 1    | rwh  | <b>Carry Flag</b><br>$0_B$ No carry/borrow bit produced<br>$1_B$ Carry/borrow bit produced                                                                                    |
| <b>N</b>    | 0    | rwh  | <b>Negative Result</b><br>$0_B$ ALU result is not negative<br>$1_B$ ALU result is negative                                                                                    |

**ALU/MAC Status (N, C, V, Z, E)**

The condition flags (N, C, V, Z, E) within the PSW indicate the ALU status after the most recently performed ALU operation. They are set by most of the instructions according to specific rules which depend on the ALU or data movement operation performed by an instruction.

After execution of an instruction which explicitly updates the PSW register, the condition flags cannot be interpreted as described below because any explicit write to the PSW register supersedes the condition flag values which are implicitly generated by the CPU. Explicitly reading the PSW register supplies a read value which represents the state of the PSW register after execution of the immediately preceding instruction.

*Note: After reset, all of the ALU status bits are cleared.*

## Central Processing Unit (CPU)

**N-Flag:** For most of the ALU operations, the N-flag is set to 1, if the most significant bit of the result contains a 1; otherwise, it is cleared. In the case of integer operations, the N-flag can be interpreted as the sign bit of the result (negative: N = 1, positive: N = 0). Negative numbers are always represented as the 2's complement of the corresponding positive number. The range of signed numbers extends from  $-8000_H$  to  $+7FFF_H$  for the word data type, or from  $-80_H$  to  $+7F_H$  for the byte data type. For Boolean bit operations with only one operand, the N-flag represents the previous state of the specified bit. For Boolean bit operations with two operands, the N-flag represents the logical XORing of the two specified bits.

**C-Flag:** After an addition, the C-flag indicates that a carry from the most significant bit of the specified word or byte data type has been generated. After a subtraction or a comparison, the C-flag indicates a borrow which represents the logical negation of a carry for the addition.

This means that the C-flag is set to 1, if **no** carry from the most significant bit of the specified word or byte data type has been generated during a subtraction, which is performed internally by the ALU as a 2's complement addition, and, the C-flag is cleared when this complement addition caused a carry.

The C-flag is always cleared for logical, multiply and divide ALU operations, because these operations cannot cause a carry.

For shift and rotate operations, the C-flag represents the value of the bit shifted out last. If a shift count of zero is specified, the C-flag will be cleared. The C-flag is also cleared for a prioritize ALU operation, because a 1 is never shifted out of the MSB during the normalization of an operand.

For Boolean bit operations with only one operand, the C-flag is always cleared. For Boolean bit operations with two operands, the C-flag represents the logical ANDing of the two specified bits.

**V-Flag:** For addition, subtraction, and 2's complementation, the V-flag is always set to 1 if the result exceeds the range of 16-bit signed numbers for word operations ( $-8000_H$  to  $+7FFF_H$ ), or 8-bit signed numbers for byte operations ( $-80_H$  to  $+7F_H$ ). Otherwise, the V-flag is cleared. Note that the result of an integer addition, integer subtraction, or 2's complement is not valid if the V-flag indicates an arithmetic overflow.

For multiplication and division, the V-flag is set to 1 if the result cannot be represented in a word data type; otherwise, it is cleared. Note that a division by zero will always cause an overflow. In contrast to the result of a division, the result of a multiplication is valid whether or not the V-flag is set to 1.

Because logical ALU operations cannot produce an invalid result, the V-flag is cleared by these operations.

The V-flag is also used as a 'Sticky Bit' for rotate right and shift right operations. With only using the C-flag, a rounding error caused by a shift right operation can be estimated up to a quantity of one half of the LSB of the result. In conjunction with the V-flag, the C-flag allows evaluation of the rounding error with a finer resolution (see [Table 5-22](#)).

## Central Processing Unit (CPU)

For Boolean bit operations with only one operand, the V-flag is always cleared. For Boolean bit operations with two operands, the V-flag represents the logical ORing of the two specified bits.

**Table 5-22 Shift Right Rounding Error Evaluation**

| C-Flag | V-Flag | Rounding Error Quantity                               |
|--------|--------|-------------------------------------------------------|
| 0      | 0      | No rounding error                                     |
| 0      | 1      | $0 < \text{Rounding error} < \frac{1}{2} \text{ LSB}$ |
| 1      | 0      | $\text{Rounding error} = \frac{1}{2} \text{ LSB}$     |
| 1      | 1      | $\text{Rounding error} > \frac{1}{2} \text{ LSB}$     |

**Z-Flag:** The Z-flag is normally set to 1 if the result of an ALU operation equals zero, otherwise it is cleared.

For the addition and subtraction with carry, the Z-flag is only set to 1, if the Z-flag already contains a 1 and the result of the current ALU operation also equals zero. This mechanism is provided to support multiple precision calculations.

For Boolean bit operations with only one operand, the Z-flag represents the logical negation of the previous state of the specified bit. For Boolean bit operations with two operands, the Z-flag represents the logical NORing of the two specified bits. For the prioritize ALU operation, the Z-flag indicates whether the second operand was zero.

**E-Flag:** End of table flag. The E-flag can be altered by instructions which perform ALU or data movement operations. The E-flag is cleared by those instructions which cannot be reasonably used for table search operations. In all other cases, the E-flag value depends on the value of the source operand to signify whether the end of a search table is reached or not. If the value of the source operand of an instruction equals the lowest negative number which is representable by the data format of the corresponding instruction ( $8000_H$  for the word data type, or  $80_H$  for the byte data type), the E-flag is set to 1; otherwise, it is cleared.

## General Control Functions (USR0, USR1, BANK, HLDEN)

A few bits in register PSW are dedicated to general control functions. Thus, they are saved and restored automatically upon task switches and interrupts.

**USR0/USR1-Flags:** These bits can be set automatically during the execution of repeated MAC instructions. These bits can also be used as general flags by an application.

**BANK:** Bitfield BANK selects the currently active register bank (local or global). Bitfield BANK is updated implicitly by hardware upon entering an interrupt service routine, and by a RETI instruction. It can be also modified explicitly via software by any instruction which can write to PSW.

## Central Processing Unit (CPU)

**HLDEN:** Setting this bit for the first time activates the selected bus arbitration mode. Bus arbitration can be disabled by temporarily clearing bit HLDEN. In this case the bus is locked, while the bus arbitration mode remains selected. Please refer to the External Bus Controller (EBC) chapter for functional details. Note that the HLDEN bit can be accessed only when memory protection (MPU) is disabled.

### Protection Level (PL0, PL1)

These flags specify the current protection level of the system. This information is needed for systems implementing memory protection (i.e. MPU). Four different protection levels are defined according to the table below. Refer to the Memory Protection (MPU) chapter for more information on how the protection system works.

**Table 5-23 Decoding of Protection Level**

| PL1 | PL0 | Protection Level   |
|-----|-----|--------------------|
| 0   | 0   | Protection Level 0 |
| 0   | 1   | Protection Level 1 |
| 1   | 0   | Protection Level 2 |
| 1   | 1   | Protection Level 3 |

A write into bit PSW.10 will be interpreted as a write into PL1 when the MPU is enabled or as a write into HLDEN when the MPU is disabled. Considering this fact it is possible to use both the EBC arbitration and MPU functionalities. Note that software made to support the external master functionality, i.e. trying to write into this HLDEN bit, may not have write permission when the MPU is enabled unless it runs in privileged mode.

### CPU Interrupt Status (IEN, ILVL)

**IEN:** The Interrupt Enable bit allows interrupts to be globally enabled ( $IEN = 1$ ) or disabled ( $IEN = 0$ ).

**ILVL:** The four-bit Interrupt Level field (ILVL) specifies the priority of the current CPU activity. The interrupt level is updated by hardware on entry into an interrupt service routine, but it can also be modified via software to prevent other interrupts from being acknowledged. If an interrupt level 15 has been assigned to the CPU, it has the highest possible priority; thus, the current CPU operation cannot be interrupted except by hardware traps or external non-maskable interrupts.

After reset, all interrupts are globally disabled, and the lowest priority ( $ILVL = 0$ ) is assigned to the initial CPU activity.

### 5.8.1 16-bit Adder/Subtractor, Barrel Shifter, and 16-bit Logic Unit

All standard arithmetic and logical operations are performed by the 16-bit ALU. In case of byte operations, signals from bits 6 and 7 of the ALU result are used to control the

## Central Processing Unit (CPU)

condition flags. Multiple precision arithmetic is supported by a “CARRY-IN” signal to the ALU from previously calculated portions of the desired operation.

A 16-bit barrel shifter provides multiple bit shifts in a single cycle. Rotations and arithmetic shifts are also supported.

### 5.8.2 Bit Manipulation Unit

The XC27x5X offers a large number of instructions for bit processing. These instructions are typically used to -

- manipulate software bit flags within CPU registers, GPRs or DPRAM
- control on-chip PD+Bus peripherals and port logic via control bits of their respective bit addressable (E)SFRs.

The bit manipulation instructions allow short addressing mode with bitoff operands only (see [Chapter 5.7.1](#)).

*Note: All GPRs are bit-addressable independently from the allocation of the register bank via the Context Pointer (CP). Even GPRs which are allocated to non-bit-addressable RAM locations provide this feature.*

Instructions BSET, BCLR, BAND, BOR, BXOR, BMOV, BMOVN explicitly set or clear specific bits. The bitfield instructions BFLDL and BFLDH allow masked manipulation of up to 8 bits of a specific byte at one time. The instructions JBC and JNBS implicitly clear or set the specified bit when the jump is taken. The instructions JB and JNB evaluate the specified bit to determine if the jump is to be taken.

*Note: Bit operations on undefined bit locations will always read a bit value of ‘0’, while the write access will not affect the respective bit location.*

#### Bit protection of PD+Bus register bits

All instructions that manipulate single bits or bit groups use a read-modify-write sequence that accesses the whole word containing the specified bit(s). The read-modify-write approach may be critical with hardware affected bits of type ‘rwh’ or ‘wh’. In these cases, the hardware may change other bits of the register while the read-modify-write operation is in progress. Thus the writeback could overwrite the new bit value generated by the hardware. To handle this side effect the bit addressable PD+Bus registers support a protection mechanism using a protection mask.

#### Example:

```
BCLR      EOPIC.EOPIE      ; disable 'end of PEC' interrupts
```

The instruction will clear the interrupt enable bit EOPIE while the ‘rwh’ bit EOPIR will be mask protected. This ensures that an EOP interrupt occurring exactly at the same time will be correctly flagged.

*Note: For the BFLD(LH) instructions the protection mask must be supplied by the programmer.*

## Central Processing Unit (CPU)

*Note: If a direct conflict occurs between a bit manipulation generated by hardware and an intended software access on the **same** bit, the software access has priority and determines the final value of the respective bit.*

## Central Processing Unit (CPU)

### 5.8.3 Multiply and Divide Unit

The XC27x5X's multiply and divide unit has two separated parts. One is the fast  $16 \times 16$ -bit multiplier that executes a multiplication in one CPU cycle. The other one is a division sub-unit which performs the division algorithm in 18 ... 21 CPU cycles (depending on the data and division types). The divide instruction requires four CPU cycles to be executed. For performance reasons, the rest of the division algorithm runs in the background during the following seventeen CPU cycles, while further instructions are executed in parallel. Interrupt tasks can also be started and executed immediately without any delay. If an instruction (from the original instruction stream or from the interrupt task) tries to use the unit while a division is still running, the execution of this new instruction is stalled until the previous division is finished.

To avoid these stalls, the multiply and division unit should not be used during the first fourteen CPU cycles of the interrupt tasks. For example, this requires up to fourteen one-cycle instructions to be executed between the interrupt entry and the first instruction which uses the multiply and divide unit again (worst case).

Multiplications and divisions implicitly use the 32-bit multiply/divide register MD (represented by the concatenation of the two non-bit-addressable data registers MDH and MDL) and the associated control register MDC. This bit-addressable 16-bit register is implicitly used by the CPU when it performs a division or multiplication in the ALU.

After a multiplication, MD represents the 32-bit result. For long divisions, MD must be loaded with the 32-bit dividend before the division is started. After any division, register MDH represents the 16-bit remainder, register MDL represents the 16-bit quotient.

#### MDH

| MDH |    |    |    |    |    |   |   |   |   |   |   |   |   |   | SFR (FE0C <sub>H</sub> /06 <sub>H</sub> ) |     |  |  |
|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------------------------------------------|-----|--|--|
| 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                                         | rwh |  |  |
| MDH |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                                           |     |  |  |

| Field | Bits   | Type | Description                                                                                          |
|-------|--------|------|------------------------------------------------------------------------------------------------------|
| MDH   | [15:0] | rwh  | <b>High Part of MD</b><br>The high order sixteen bits of the 32-bit multiply and divide register MD. |

## Central Processing Unit (CPU)

**MDL**
**Multiply Divide Low Word**
**SFR (FE0E<sub>H</sub>/07<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**


| Field      | Bits   | Type | Description                                                                                        |
|------------|--------|------|----------------------------------------------------------------------------------------------------|
| <b>MDL</b> | [15:0] | rwh  | <b>Low Part of MD</b><br>The low order sixteen bits of the 32-bit multiply and divide register MD. |

Whenever MDH or MDL is updated via software, the Multiply/Divide Register In Use flag (MDRIU) in the Multiply/Divide Control register (MDC) is set to '1'. The MDRIU flag is cleared, whenever register MDL is read via software.

**MDC**
**Multiply Divide Control**
**SFR (FF0E<sub>H</sub>/87<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**


| Field        | Bits          | Type | Description                                                                                                                                                                                        |
|--------------|---------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>MDRIU</b> | 4             | rwh  | <b>Multiply/Divide Register In Use</b><br>$0_B$ Cleared when MDL is read via software.<br>$1_B$ Set when MDL or MDH is written via software, or when a multiply or divide instruction is executed. |
| <b>0</b>     | [15:5], [3:0] | r    | <b>Reserved</b><br>Read as 0, should be written 0                                                                                                                                                  |

*Note: The MDRIU flag indicates the usage of register MD (MDL and MDH). In this case MD must be saved prior to a new multiplication or division operation.*

## Central Processing Unit (CPU)

## 5.9 DSP Data Processing (MAC Unit)

The CoXXX arithmetic instructions are executed by the MAC unit. It provides single-instruction-cycle, non-pipelined, 32-bit additions; 32-bit subtraction; right and left shifts; 16-bit by 16-bit multiplication; and multiplication with cumulative subtraction/addition. The MAC unit includes the following major components also shown in [Figure 5-16](#):

- 16-bit by 16-bit signed/unsigned multiplier with signed result<sup>1)</sup>
- Concatenation Unit
- Scaler (one-bit left shifter) for fractional computing
- 40-bit Adder/Subtracter
- 40-bit Signed Accumulator
- Data Limiter
- Accumulator Shifter
- Repeat Counter



**Figure 5-16 Functional MAC Unit Block Diagram**

1) The same hardware-multiplier is used in the ALU.

### 5.9.1 MAC Unit Control

The working register of the MAC unit is a dedicated 40-bit accumulator register. A set of consistent flags is automatically updated in status register MSW after each MAC operation. These flags allow branching on specific conditions. Unlike the PSW flags, these flags are not preserved automatically by the CPU upon entry into an interrupt or trap routine. All dedicated MAC registers must be saved on the stack if the MAC unit is shared between different tasks and interrupts. General properties of the MAC unit are selected via the MAC control word MCW.

#### MCW

**MAC Control Word**      **SFR (FFDC<sub>H</sub>/EE<sub>H</sub>)**      **Reset Value: 0000<sub>H</sub>**



| Field     | Bits           | Type | Description                                                                                                                                   |
|-----------|----------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| <b>MP</b> | 10             | rw   | <b>One-Bit Scaler Control</b><br>$0_B$ Multiplier product shift disabled<br>$1_B$ Multiplier product shift enabled for signed multiplications |
| <b>MS</b> | 9              | rw   | <b>Saturation Control</b><br>$0_B$ Saturation disabled<br>$1_B$ Saturation to 32-bit value enabled                                            |
| <b>0</b>  | [15:11], [8:0] | r    | <b>Reserved</b><br>Read as 0, should be written 0                                                                                             |

### 5.9.2 Representation of Numbers and Rounding

The XC27x5X supports the 2's complement representation of binary numbers. In this format, the sign bit is the MSB of the binary word. This is set to zero for positive numbers and set to one for negative numbers. Unsigned numbers are supported only by multiply/multiply-accumulate instructions which specify whether each operand is signed or unsigned.

In 2's complement fractional format, the N-bit operand is represented using the 1.[N-1] format (1 signed bit, N-1 fractional bits). Such a format can represent numbers between -1 and  $+1 - 2^{[N-1]}$ . This format is supported when bit MP of register MCW is set.

## Central Processing Unit (CPU)

The XC27x5X implements 2's complement rounding. With this rounding type, one is added to the bit to the right of the rounding point (bit 15 of MAL), before truncation (MAL is cleared).

### 5.9.3 The 16-bit by 16-bit Signed/Unsigned Multiplier and Scaler

The multiplier executes 16-bit by 16-bit parallel signed/unsigned fractional and integer multiplication in one CPU-cycle. The multiplier allows the multiplication of unsigned and signed operands. The result is always presented in a signed fractional or integer format. The result of the multiplication feeds a one-bit scaler to allow compensation for the extra sign bit gained in multiplying two 16-bit 2's complement numbers.

### 5.9.4 Concatenation Unit

The concatenation unit enables the MAC unit to perform 32-bit arithmetic operations in one CPU cycle. The concatenation unit concatenates two 16-bit operands to a 32-bit operand before the 32-bit arithmetic operation is executed in the 40-bit adder/subtractor. The second required operand is always the current accumulator contents. The concatenation unit is also used to pre-load the accumulator with a 32-bit value.

### 5.9.5 One-bit Scaler

The one-bit scaler can shift the result of the concatenation unit or the output of the multiplier one bit to the left. The scaler is controlled by the executed instruction for the concatenation or by control bit MP in register MCW.

If bit MP is set the product is shifted one bit to the left to compensate for the extra sign bit gained in multiplying two 16-bit 2's-complement numbers. The enabled automatic shift is performed only if both input operands are signed.

### 5.9.6 The 40-bit Adder/Subtractor

The 40-bit Adder/Subtractor allows intermediate overflows in a series of multiply/accumulate operations. The Adder/Subtractor has two input ports. The 40-bit port is the feedback of the accumulator output through the ACCU-Shifter to the Adder/Subtractor. The 32-bit port is the input port for the operand coming from the one-bit Scaler. The 32-bit operands are signed and extended to 40 bits before the addition/subtraction is performed.

The output of the Adder/Subtractor goes to the accumulator. It is also possible to round the result and to saturate it on a 32-bit value automatically after every accumulation. The round operation is performed by adding  $00'0000'8000_H$  to the result. Automatic saturation is enabled by setting the saturation control bit MS in register MCW.

When the accumulator is in the overflow saturation mode and an overflow occurs, the accumulator is loaded with either the most positive or the most negative value

## Central Processing Unit (CPU)

representable in a 32-bit value, depending on the direction of the overflow as well as on the arithmetic used. The value of the accumulator upon saturation is either 00'7FFF'FFFF<sub>H</sub> (positive) or FF'8000'0000<sub>H</sub> (negative).

### 5.9.7 The Data Limiter

Saturation arithmetic is also provided to selectively limit overflow when reading the accumulator by means of a **CoSTORE <destination>, MAS** instruction. Limiting is performed on the MAC-Unit accumulator. If the contents of the accumulator can be represented in the destination operand size without overflow, then the data limiter is disabled and the operand is not modified. If the contents of the accumulator cannot be represented without overflow in the destination operand size, the limiter will substitute a “limited” data as explained in **Table 5-24**:

**Table 5-24 Limiter Output**

| ME-flag | MN-flag | Output of Limiter |
|---------|---------|-------------------|
| 0       | x       | unchanged         |
| 1       | 0       | 7FFF <sub>H</sub> |
| 1       | 1       | 8000 <sub>H</sub> |

*Note: In this particular case, both the accumulator and the status register are not affected. MAS is readable by means of a CoSTORE instruction only.*

### 5.9.8 The Accumulator Shifter

The accumulator shifter is a parallel shifter with a 40-bit input and a 40-bit output. The source accumulator shifting operations are:

- No shift (Unmodified)
- Up to 16-bit Arithmetic Left Shift
- Up to 16-bit Arithmetic Right Shift

Notice that bits ME, MSV, and MSL in register MSW are affected by left shifts; therefore, if the saturation mechanism is enabled (MS) the behavior is similar to the one of the Adder/Subtractor.

*Note: Certain precautions are required in case of left shift with saturation enabled. Generally, if MAE contains significant bits, then the 32-bit value in the accumulator is to be saturated. However, it is possible that left shift may move some significant bits out of the accumulator. The 40-bit result will be misinterpreted and will be either not saturated or saturated incorrectly. There is a chance that the result of left shift may produce a result which can saturate an original positive number to the minimum negative value, or vice versa.*

## Central Processing Unit (CPU)

### 5.9.9 The 40-bit Signed Accumulator Register

The 40-bit accumulator consists of three concatenated registers MAE, MAH, and MAL. MAE is 8 bits wide, MAH and MAL are 16 bits wide. MAE is the Most Significant Byte of the 40-bit accumulator. This byte performs a guarding function. MAE is accessed as the lower byte of register MSW.

When MAH is written, the value in the accumulator is automatically adjusted to signed extended 40-bit format. That means MAL is cleared and MAE will be automatically loaded with zeros for a positive number (the most significant bit of MAH is 0), and with ones for a negative number (the most significant bit of MAH is 1), representing the extended 40-bit negative number in 2's complement notation. One may see that the extended 40-bit value is equal to the 32-bit value without extension. In other words, after this extension, MAE does not contain significant bits. Generally, this condition is present when the highest 9 bits of the 40-bit signed result are the same.

During the accumulator operations, an overflow may happen and the result may not fit into 32 bits and MAE will change. The extension flag "E" in register MSW is set when the signed result in the accumulator has exceeded the 32-bit boundary. This condition is present when the highest 9 bits of the 40-bit signed result are not the same, i.e. MAE contains significant bits.

Most CoXXX operations specify the 40-bit accumulator register as a source and/or a destination operand.

#### MAL

##### Accumulator Low Word

##### SFR (FE5C<sub>H</sub>/2E<sub>H</sub>)

##### Reset Value: 0000<sub>H</sub>



| Field | Bits   | Type | Description                                                                                                               |
|-------|--------|------|---------------------------------------------------------------------------------------------------------------------------|
| MAL   | [15:0] | rwh  | <b>Low Part of Accumulator</b><br>The 40-bit accumulator is completed by the accumulator high word (MAH) and bitfield MAE |

## Central Processing Unit (CPU)

**MAH**
**Accumulator High Word**
**SFR (FE5E<sub>H</sub>/2F<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**


| Field      | Bits   | Type | Description                                                                                                               |
|------------|--------|------|---------------------------------------------------------------------------------------------------------------------------|
| <b>MAH</b> | [15:0] | rwh  | <b>High Part of Accumulator</b><br>The 40-bit accumulator is completed by the accumulator low word (MAL) and bitfield MAE |

## Central Processing Unit (CPU)

### 5.9.10 The MAC Unit Status Word MSW

The upper byte of register MSW (bit-addressable) shows the current status of the MAC Unit. The lower byte of register MSW represents the 8-bit MAC accumulator extension, building the 40-bit accumulator together with registers MAH and MAL.

**MSW**
**MAC Status Word**
**SFR (FFDE<sub>H</sub>/EF<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**

| 15 | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|----|-----|-----|-----|-----|-----|-----|-----|-----|---|---|---|---|---|---|-----|
| 0  | MV  | MSL | ME  | MSV | MC  | MZ  | MN  |     |   |   |   |   |   |   | MAE |
| r  | rwh |   |   |   |   |   |   | rwh |

| Field | Bits | Type | Description                                                                                                                       |
|-------|------|------|-----------------------------------------------------------------------------------------------------------------------------------|
| 0     | 15   | r    | <b>Reserved</b><br>Read as 0, should be written 0                                                                                 |
| MV    | 14   | rwh  | <b>Overflow Flag</b><br>0 <sub>B</sub> No Overflow produced<br>1 <sub>B</sub> Overflow produced                                   |
| MSL   | 13   | rwh  | <b>Sticky Limit Flag</b><br>0 <sub>B</sub> Result was not saturated<br>1 <sub>B</sub> Result was saturated                        |
| ME    | 12   | rwh  | <b>MAC Extension Flag</b><br>0 <sub>B</sub> MAE does not contain significant bits<br>1 <sub>B</sub> MAE contains significant bits |
| MSV   | 11   | rwh  | <b>Sticky Overflow Flag</b><br>0 <sub>B</sub> No Overflow occurred<br>1 <sub>B</sub> Overflow occurred                            |
| MC    | 10   | rwh  | <b>Carry Flag</b><br>0 <sub>B</sub> No carry/borrow produced<br>1 <sub>B</sub> Carry/borrow produced                              |
| MZ    | 9    | rwh  | <b>Zero Flag</b><br>0 <sub>B</sub> MAC result is not zero<br>1 <sub>B</sub> MAC result is zero                                    |
| MN    | 8    | rwh  | <b>Negative Result</b><br>0 <sub>B</sub> MAC result is positive<br>1 <sub>B</sub> MAC result is negative                          |

## Central Processing Unit (CPU)

| Field      | Bits  | Type | Description                                                                                                               |
|------------|-------|------|---------------------------------------------------------------------------------------------------------------------------|
| <b>MAE</b> | [7:0] | rwh  | <b>MAC Accumulator Extension</b><br>The most significant bits of the 40-bit accumulator, completing registers MAH and MAL |

**MAC Unit Status (MV, MN, MZ, MC, MSV, ME, MSL)**

These condition flags indicate the MAC status resulting from the most recently performed MAC operation. These flags are controlled by the majority of MAC instructions according to specific rules. Those rules depend on the instruction managing the MAC or data movement operation.

After execution of an instruction which explicitly updates register MSW, the condition flags may no longer represent an actual MAC status. An explicit write operation to register MSW supersedes the condition flag values implicitly generated by the MAC unit. An explicit read access returns the value of register MSW after execution of the immediately preceding instruction. Register MSW can be accessed via any instruction capable of accessing an SFR.

*Note: After reset, all MAC status bits are cleared.*

**MN-Flag:** For the majority of the MAC operations, the MN-flag is set to 1 if the most significant bit of the result contains a 1; otherwise, it is cleared. In the case of integer operations, the MN-flag can be interpreted as the sign bit of the result (negative: MN = 1, positive: MN = 0). Negative numbers are always represented as the 2's complement of the corresponding positive number. The range of signed numbers extends from 80'0000'0000<sub>H</sub> to 7F'FFFF'FFFF<sub>H</sub>.

**MZ-Flag:** The MZ-flag is normally set to 1 if the result of a MAC operation equals zero; otherwise, it is cleared.

**MC-Flag:** After a MAC addition, the MC-flag indicates that a “Carry” from the most significant bit of the accumulator extension MAE has been generated. After a MAC subtraction or a MAC comparison, the MC-flag indicates a “Borrow” representing the logical negation of a “Carry” for the addition. This means that the MC-flag is set to 1 if no “Carry” from the most significant bit of the accumulator has been generated during a subtraction. Subtraction is performed by the MAC Unit as a 2's complement addition and the MC-flag is cleared when this complement addition caused a “Carry”.

For left-shift MAC operations, the MC-flag represents the value of the bit shifted out last. Right-shift MAC operations always clear the MC-flag. The arithmetic right-shift MAC operation can set the MC-flag if the enabled round operation generates a “Carry” from the most significant bit of the accumulator extension MAE.

**MSV-Flag:** The addition, subtraction, 2's complement, and round operations always set the MSV-flag to 1 if the MAC result exceeds the maximum range of 40-bit signed numbers. If the MSV-flag indicates an arithmetic overflow, the MAC result of an operation is not valid.

## Central Processing Unit (CPU)

The MSV-flag is a ‘Sticky Bit’. Once set, other MAC operations cannot affect the status of the MSV-flag. Only a direct write operation can clear the MSV-flag.

**ME-Flag:** The ME-flag is set if the accumulator extension MAE contains significant bits, that means if the nine highest accumulator bits are not all equal.

**MSL-Flag:** The MSL-flag is set if an automatic saturation of the accumulator has happened. The automatic saturation is enabled if bit MS in register MCW is set. The MSL-Flag can be also set by instructions which limit the contents of the accumulator. If the accumulator has been limited, the MSL-Flag is set.

The MSL-Flag is a ‘Sticky Bit’. Once set, it cannot be affected by the other MAC operations. Only a direct write operation can clear the MSL-flag.

**MV-Flag:** The addition, subtraction, and accumulation operations set the MV-flag to 1 if the result exceeds the maximum range of signed numbers ( $80'0000'0000_H$  to  $7F'FFFF'FFFF_H$ ); otherwise, the MV-flag is cleared. Note that if the MV-flag indicates an arithmetic overflow, the result of the integer addition, integer subtraction, or accumulation is not valid.

### 5.9.11 The Repeat Counter MRW

The Repeat Counter MRW controls the number of repetitions a loop must be executed. The register must be pre-loaded before it can be used with -USR<sub>x</sub> CoXXX operations. MAC operations are able to decrement this counter. When a -USR<sub>x</sub> CoXXX instruction is executed, MRW is checked for zero **before** being decremented. If MRW equals zero, bit USRx is set and MRW is not further decremented. Register **MRW** can be accessed via any instruction capable of accessing a SFR.

#### MRW

MAC Repeat Word

SFR (FFDA<sub>H</sub>/ED<sub>H</sub>)

Reset Value: 0000<sub>H</sub>



| Field       | Bits   | Type | Description        |
|-------------|--------|------|--------------------|
| REPEATCOUNT | [15:0] | rwh  | MAC repeat counter |

All CoXXX instructions have a 3-bit wide repeat control field ‘rrr’ (bit positions [31:29]) in the operand field to control the MRW repeat counter. [Table 5-25](#) lists the possible encodings.

## Central Processing Unit (CPU)

**Table 5-25 Encoding of MAC Repeat Word Control**

| <b>Code in 'rrr'</b> | <b>Effect on Repeat Counter</b>                                                          |
|----------------------|------------------------------------------------------------------------------------------|
| $000_B$              | regular CoXXX instruction                                                                |
| $001_B$              | RESERVED                                                                                 |
| $010_B$              | '-USR0 CoXXX' instruction,<br>decrements repeat counter and sets bit USR0 if MRW is zero |
| $011_B$              | '-USR1 CoXXX' instruction,<br>decrements repeat counter and sets bit USR1 if MRW is zero |
| $1XX_B$              | RESERVED                                                                                 |

*Note: Bit USR0 has been a general purpose flag also in previous architectures. To prevent collisions due to using this flag by programmer or compiler, use '-USR0 CoXXX' instructions very carefully.*

The following example shows a loop which is executed 20 times. Every time the CoMACM instruction is executed, the MRW counter is decremented.

```

        MOV      MRW, #19          ;Pre-load loop counter
loop01:
-USR1   CoMACM [IDX0+], [R0+]    ;Calculate and decrement MSW
        ADD      R2, #0002H
        JMPA    cc_nusr1, loop01 ;Repeat loop until USR1 is set
    
```

*Note: Because correctly predicted JMPA is executed in 0-cycle, it offers the functionality of a repeat instruction.*

## 5.10 Constant Registers

All bits of these bit-addressable registers are fixed to 0 or 1 by hardware. These registers can be read only. Register ZEROS/ONES can be used as a register-addressable constant of all zeros or all ones, for example for bit manipulation or mask generation. The constant registers can be accessed via any instruction capable of addressing an SFR.

### ZEROS

#### Zeros Register

 SFR (FF1C<sub>H</sub>/8E<sub>H</sub>)

 Reset Value: 0000<sub>H</sub>


| Field | Bits | Type | Description |
|-------|------|------|-------------|
|-------|------|------|-------------|

|      |        |   |                    |
|------|--------|---|--------------------|
| ZERO | [15:0] | r | Constant Zero Bits |
|------|--------|---|--------------------|

### ONES

#### Ones Register

 SFR (FF1E<sub>H</sub>/8F<sub>H</sub>)

 Reset Value: FFFF<sub>H</sub>


| Field | Bits | Type | Description |
|-------|------|------|-------------|
|-------|------|------|-------------|

|     |        |   |                   |
|-----|--------|---|-------------------|
| ONE | [15:0] | r | Constant One Bits |
|-----|--------|---|-------------------|

### CPUID

#### CPU Identification Register

 ESFR (F00C<sub>H</sub>/06<sub>H</sub>)

 Reset Value: 0313<sub>H</sub>


| Field | Bits | Type | Description |
|-------|------|------|-------------|
|-------|------|------|-------------|

|              |        |   |                                          |
|--------------|--------|---|------------------------------------------|
| MODULENUMBER | [15:8] | r | C166 Family CPU Module Number (C166S-V2) |
|--------------|--------|---|------------------------------------------|

## Central Processing Unit (CPU)

| Field         | Bits  | Type | Description                 |
|---------------|-------|------|-----------------------------|
| VERSIONNUMBER | [7:0] | r    | C166S-V2 CPU Version Number |



## Memory Protection Unit (MPU)

# 6 Memory Protection Unit (MPU)

The Memory Protection Unit (MPU) provides the hardware mechanisms needed for implementing memory protection. The MPU allows detection of unauthorized accesses (read, write or instruction fetch) in user-defined memory ranges. It offers protection for the complete address space, including the peripheral area.

The MPU can be used to support the encapsulation of different applications or software components running on the processor. This encapsulation provides the means to ensure integrity and fault isolation capabilities in today's complex systems relying on multiple-sources software.

## 6.1 Functional Overview

Different protection levels are usually needed to support a programming system where for example an operating system or software kernel runs and controls different application and low level drivers parts. One level can be associated to the operating system and for the other tasks that need protection against each other or against the operating system, other levels can be used. For every protection level different address ranges with different access permissions for instructions and/or data can be defined. When a piece of code is executed and the memory protection is enabled, the permissions associated to its protection level are selected and every time a memory access is performed it will be checked if the access is outside of the specified ranges or violates the access permissions. In this case the access may not be performed but marked as invalid and a protection trap routine can be executed.

The basic MPU functionality is shown in [Figure 6-1](#).



**Figure 6-1 MPU operation**

## Memory Protection Unit (MPU)

Four Protection Levels can coexist during run time in this architecture. Two bits in the Processor Status Word (PSW) are used to select which protection level is active at a given time. If an application requires more than 4 protection levels, a re-mapping of all the levels to the 4 possible values has to be performed and during run time re-programming of the protection register sets when switching levels is needed.

A protection register set is associated to every protection level, every set contains all the address ranges and the access permissions associated to the corresponding protection level. Every protection register set can contain a programmable number of range registers. All together, a maximum of 12 ranges is supported. Associated to every code or data range, a protection mode register defines the permissions for this range. Refer to the next chapters for a detailed explanation of the MPU registers needed for the protection system and its usage.

**Memory Protection Unit (MPU)**

## 6.2 Memory Protection Registers

A protection register set consists of a variable number of Protection Range register pairs (PRUx/PRLx) and the corresponding number of Protection Mode registers (PMx). The PMx registers are located in the SFRs area and are accessed through the Peripheral Data Bus -PD-Bus-. The PRUx/PRLx registers are not memory mapped, their access mechanism is supported through the memory mapped registers Protection Range Address register (PRA) and Protection Range Data register (PRD).

**Table 6-1 Registers Address Space**

| Module | Base Address   | End Address | Note |
|--------|----------------|-------------|------|
| MPU    | 0 <sub>H</sub> |             |      |

**Table 6-2 Registers Overview**

| Register Short Name | Register Long Name                      | Offset Address    | Page Number         |
|---------------------|-----------------------------------------|-------------------|---------------------|
| PRUx (x =0-11)      | Protection Range Register x Upper Bound | none <sub>H</sub> | <a href="#">6-4</a> |
| PRLx (x =0-11)      | Protection Range Register x Lower Bound | none <sub>H</sub> | <a href="#">6-4</a> |
| PM5                 | Protection Mode Register 5              | FFD2 <sub>H</sub> | <a href="#">6-7</a> |
| PM4                 | Protection Mode Register 4              | FFD0 <sub>H</sub> | <a href="#">6-7</a> |
| PM3                 | Protection Mode Register 3              | FFCE <sub>H</sub> | <a href="#">6-7</a> |
| PM2                 | Protection Mode Register 2              | FFCC <sub>H</sub> | <a href="#">6-7</a> |
| PM1                 | Protection Mode Register 1              | FFCA <sub>H</sub> | <a href="#">6-7</a> |
| PM0                 | Protection Mode Register 0              | FFC8 <sub>H</sub> | <a href="#">6-7</a> |
| PRD                 | Protection Range Data                   | FFC6 <sub>H</sub> | <a href="#">6-8</a> |
| PRA                 | Protection Range Address                | FFC4 <sub>H</sub> | <a href="#">6-9</a> |

### 6.2.1 Protection Range Registers

The PRUx/PRLx pairs are 16-bits registers and specify the upper 16 bits of the physical addresses, upper and lower bound, for data and/or code for all the allowed ranges (12 is the maximum supported). Only these upper 16 bits of the physical addresses are considered in the address comparisons, as a consequence, the minimum granularity of the ranges is 256 bytes and all the ranges are aligned to this size.

The PRUx and PRLx registers specify respectively the Upper and Lower addresses of a Range. If due to a programming error PRLx specifies a value bigger than PRUx, the

**Memory Protection Unit (MPU)**

corresponding range will not specify a correct address range, and as a consequence the corresponding range is useless (i.e. ignored).

For programming a protection range in the PRUx/PRLx registers, it has to be selected first which range is going to be written by programming the address into PRA, then the data write operation can be performed by writing the data into PRD. In a similar way, a read operation has to be performed by selecting first which range is going to be read (by programming the address into PRA) and then the read operation can be performed by reading PRD. Programming a PRUx/PRLx register requires then two write operations. Similarly, reading a PRUx/PRLx register requires also two operations (one write and one read). For continuous accesses and when using the auto increment feature only one initialization into PRA is needed, afterwards only the PRD register needs to be written/read every time. Registers PRD and PRA are described in [Chapter 6.2.3](#) and [Chapter 6.2.4](#) respectively.

**PRUx (x =0-11)**
**Protection Range Register x Upper Bound**
**Reset Value: 0000<sub>H</sub>**


| Field  | Bits   | Type | Description                            |
|--------|--------|------|----------------------------------------|
| UPPBND | [15:0] | rw   | Upper Boundary Address (upper 16 bits) |

**PRLx (x =0-11)**
**Protection Range Register x Lower Bound**
**Reset Value: 0000<sub>H</sub>**


| Field  | Bits   | Type | Description                            |
|--------|--------|------|----------------------------------------|
| LOWBND | [15:0] | rw   | Lower Boundary Address (upper 16 bits) |

**Memory Protection Unit (MPU)**

### 6.2.2 Protection Mode Registers

All the control information associated to every address range is contained in the Protection Mode registers. Access permissions (execute, read and/or write) are defined here and also the range-to-level mapping. Every range can be individually enabled to be used for any protection level, even can be used for more than one level (but with the same access permissions). Also the field used the enable the protection system is implemented in one of the protection mode registers.

Note that no hardware mechanism is implemented to flush the pipeline upon a modification of these registers. This is usually not a problem because a (re-)programming of the MPU configuration registers should be anyhow performed having the protection disabled. Also the configuration affecting a particular protection level will be usually (re-)programmed from another level meaning that even at the point when protection is enabled the software currently running will not be affected by the configuration change (the configuration change is usually seen once the protection level is changed according to the procedure described in [Chapter 6.4.2](#)). For special cases where the change will and needs to be immediately seen, the software has to take care that the write is effective before executing the next affected instruction (by reading for example the latest written register).

The bit fields of the PMx registers in the description below use generic Range names (A, B), their mapping to the physical ranges is given after the PMx register name where they belong to. Given a Protection Mode register x, the range named A is addressing the physical range  $2^*x$  and range named B the range  $2^*x + 1$ .

The PMx registers are EINIT protected.

**PM0**
**Protection Mode Register 0**
**SFR (FFC8<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**

| 15       | 14       | 13       | 12       | 11  | 10  | 9   | 8 | 7        | 6        | 5        | 4        | 3   | 2   | 1   | 0          |
|----------|----------|----------|----------|-----|-----|-----|---|----------|----------|----------|----------|-----|-----|-----|------------|
| L3E<br>B | L2E<br>B | L1E<br>B | L0E<br>B | WEB | REB | XEB | 0 | L3E<br>A | L2E<br>A | L1E<br>A | L0E<br>A | WEA | REA | XEA | PRO<br>TEN |

| Field  | Bits | Type | Description                                                                                                                           |
|--------|------|------|---------------------------------------------------------------------------------------------------------------------------------------|
| PROTEN | 0    | rw   | <b>Protection Enable bit</b><br>This bit enables the Protection mechanism<br>$0_B$ Protection not enabled<br>$1_B$ Protection enabled |

## Memory Protection Unit (MPU)

| Field         | Bits     | Type | Description                                                                                                                                                                                 |
|---------------|----------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| XEA,<br>XEB   | 1,<br>9  | rw   | <b>Execute Enable</b><br>$0_B$ Instruction fetch accesses to associated address range (A, B) not permitted<br>$1_B$ Instruction fetch accesses to associated address range (A, B) permitted |
| REA,<br>REB   | 2,<br>10 | rw   | <b>Read Enable</b><br>$0_B$ Data read accesses to associated address range (A, B) not permitted<br>$1_B$ Data read accesses to associated address range (A, B) permitted                    |
| WEA,<br>WEB   | 3,<br>11 | rw   | <b>Write Enable</b><br>$0_B$ Data write accesses to associated address range (A, B) not permitted<br>$1_B$ Data write accesses to associated address range (A, B) permitted                 |
| L0EA,<br>L0EB | 4,<br>12 | rw   | <b>Level 0 Enable</b><br>$0_B$ Range (A, B) not enabled for Protection Level 0<br>$1_B$ Range (A, B) enabled for Protection Level 0                                                         |
| L1EA,<br>L1EB | 5,<br>13 | rw   | <b>Level 1 Enable</b><br>$0_B$ Range (A, B) not enabled for Protection Level 1<br>$1_B$ Range (A, B) enabled for Protection Level 1                                                         |
| L2EA,<br>L2EB | 6,<br>14 | rw   | <b>Level 2 Enable</b><br>$0_B$ Range (A, B) not enabled for Protection Level 2<br>$1_B$ Range (A, B) enabled for Protection Level 2                                                         |
| L3EA,<br>L3EB | 7,<br>15 | rw   | <b>Level 3 Enable</b><br>$0_B$ Range (A, B) not enabled for Protection Level 3<br>$1_B$ Range (A, B) enabled for Protection Level 3                                                         |
| 0             | 8        | r    | <b>Reserved field</b>                                                                                                                                                                       |

The field PROTEN exists only in the Protection Mode Register 0.

## Memory Protection Unit (MPU)

**PM<sub>x</sub> (x =1-5)**
**Protection Mode Register x**
**SFR (FFC8<sub>H</sub>+2\*x)**
**Reset Value: 0000<sub>H</sub>**

| 15       | 14       | 13       | 12       | 11  | 10  | 9   | 8 | 7        | 6        | 5        | 4        | 3   | 2   | 1   | 0 |
|----------|----------|----------|----------|-----|-----|-----|---|----------|----------|----------|----------|-----|-----|-----|---|
| L3E<br>B | L2E<br>B | L1E<br>B | L0E<br>B | WEB | REB | XEB | 0 | L3E<br>A | L2E<br>A | L1E<br>A | L0E<br>A | WEA | REA | XEA | 0 |
| rw       | rw       | rw       | rw       | rw  | rw  | rw  | r | rw       | rw       | rw       | rw       | rw  | rw  | rw  | r |

| Field         | Bits     | Type | Description                                                                                                                                                                                                   |
|---------------|----------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0             | 0        | r    | <b>Reserved field</b>                                                                                                                                                                                         |
| XEA,<br>XEB   | 1,<br>9  | rw   | <b>Execute Enable</b><br>0 <sub>B</sub> Instruction fetch accesses to associated address range (A, B) not permitted<br>1 <sub>B</sub> Instruction fetch accesses to associated address range (A, B) permitted |
| REA,<br>REB   | 2,<br>10 | rw   | <b>Read Enable</b><br>0 <sub>B</sub> Data read accesses to associated address range (A, B) not permitted<br>1 <sub>B</sub> Data read accesses to associated address range (A, B) permitted                    |
| WEA,<br>WEB   | 3,<br>11 | rw   | <b>Write Enable</b><br>0 <sub>B</sub> Data write accesses to associated address range (A, B) not permitted<br>1 <sub>B</sub> Data write accesses to associated address range (A, B) permitted                 |
| L0EA,<br>L0EB | 4,<br>12 | rw   | <b>Level 0 Enable</b><br>0 <sub>B</sub> Range (A, B) not enabled for Protection Level 0<br>1 <sub>B</sub> Range (A, B) enabled for Protection Level 0                                                         |
| L1EA,<br>L1EB | 5,<br>13 | rw   | <b>Level 1 Enable</b><br>0 <sub>B</sub> Range (A, B) not enabled for Protection Level 1<br>1 <sub>B</sub> Range (A, B) enabled for Protection Level 1                                                         |
| L2EA,<br>L2EB | 6,<br>14 | rw   | <b>Level 2 Enable</b><br>0 <sub>B</sub> Range (A, B) not enabled for Protection Level 2<br>1 <sub>B</sub> Range (A, B) enabled for Protection Level 2                                                         |

## Memory Protection Unit (MPU)

| Field         | Bits     | Type | Description                                                                                                                         |
|---------------|----------|------|-------------------------------------------------------------------------------------------------------------------------------------|
| L3EA,<br>L3EB | 7,<br>15 | rw   | <b>Level 3 Enable</b><br>$0_B$ Range (A, B) not enabled for Protection Level 3<br>$1_B$ Range (A, B) enabled for Protection Level 3 |
| 0             | 8        | r    | <b>Reserved field</b>                                                                                                               |

### 6.2.3 Protection Range Data Register

The Protection Range Data register contains the 16 bits data value needed to program the content of the Protection Range Registers. It also contains the data read during the last read access on the Protection Range Registers. A write into PRD triggers immediately a write into the corresponding PRUx/PRLx register (the one that is currently selected by the write pointer -in PRA register-). Also a read into PRD delivers the corresponding PRUx/PRLx data immediately (the one that is currently selected by the read pointer -in PRA register-).

The PRD register is EINIT protected.



| Field | Bits   | Type | Description                          |
|-------|--------|------|--------------------------------------|
| DATA  | [15:0] | rwh  | <b>Data Value for/from PRUx/PRLx</b> |

### 6.2.4 Protection Range Address Register

The Protection Range Address register contains two access pointers, one used for write operations and the other for read operations. With every 5-bit pointer it is possible to select a PRUx/PRLx register from a set of 24 register (the 24 PRUx/PRLx registers needed to implement 12 protection ranges).

An auto increment capability can be enabled for the access pointers (controlled by WMOD and RMOD fields), after every write or read into/from PRD the write or read pointers are incremented respectively. This feature enables a faster programming of the protection range registers. When the auto increment mode is active, the access pointers automatically do a wrap around (i.e. initialized to 0) after reaching its maximum value.

**Memory Protection Unit (MPU)**

The occurrence of a wrap around is shown in the status bits WWA or RWA. The software can then check if this situation has happened taking the corresponding action and resetting the corresponding flag.

Special care has to be taken when programming the PRA register in order not to modify one of the pointers unintentionally. It is recommended to use bit instructions for that (bit field instructions for example). Also when using the auto increment feature and during debugging it has to be considered that a debugger access can also modify the pointer values, the debugger software should then take care of restoring the original status of this register.

The PRA register is EINIT protected.

**PRA**

| Protection Range Address |     |    |      |    |    |   |          |         |   | SFR (FFC4 <sub>H</sub> ) |   |     |   | Reset Value: 0000 <sub>H</sub> |   |     |  |     |  |
|--------------------------|-----|----|------|----|----|---|----------|---------|---|--------------------------|---|-----|---|--------------------------------|---|-----|--|-----|--|
| 15                       | 14  | 13 | 12   | 11 | 10 | 9 | 8        | 7       | 6 | 5                        | 4 | 3   | 2 | 1                              | 0 |     |  |     |  |
| RMO<br>D                 | RWA | 0  | RPTR |    | rw |   | WM<br>OD | WW<br>A | 0 | WPTR                     |   | rwh |   | rwh                            |   | rwh |  | rwh |  |

| Field | Bits  | Type | Description                                                                                                                                                                                                                                                                                          |
|-------|-------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WPTR  | [4:0] | rwh  | <b>Write Pointer</b><br>Selects the Protection Range Register to be written<br>$00000_B$ Selects PRL0<br>$00001_B$ Selects PRU0<br>$00010_B$ Selects PRL1<br>$00011_B$ Selects PRU1<br>$00100_B$ Selects PRL2<br>$00101_B$ Selects PRU2<br>...<br>$11110_B$ Selects PRL15<br>$11111_B$ Selects PRU15 |
| 0     | 5     | r    | <b>Reserved field</b>                                                                                                                                                                                                                                                                                |
| WWA   | 6     | rwh  | <b>Write Wrap Around Status</b><br>$0_B$ No WPTR Wrap Around occurred on last Write<br>$1_B$ A WPTR Wrap Around occurred on last Write<br>Bit to be cleared by SW                                                                                                                                    |
| WMOD  | 7     | rw   | <b>Auto increment Write Mode</b><br>$0_B$ No increment WPTR on every Write<br>$1_B$ Auto increment WPTR on every Write                                                                                                                                                                               |

## Memory Protection Unit (MPU)

| Field | Bits   | Type | Description                                                                                                                                                                                                                                                                                      |
|-------|--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RPTR  | [12:8] | rwh  | <b>Read Pointer</b><br>Selects the Protection Range Register to be read<br>$00000_B$ Selects PRL0<br>$00001_B$ Selects PRU0<br>$00010_B$ Selects PRL1<br>$00011_B$ Selects PRU1<br>$00100_B$ Selects PRL2<br>$00101_B$ Selects PRU2<br>...<br>$11110_B$ Selects PRL15<br>$11111_B$ Selects PRU15 |
| 0     | 13     | r    | <b>Reserved field</b>                                                                                                                                                                                                                                                                            |
| RWA   | 14     | rwh  | <b>Read Wrap Around Status</b><br>$0_B$ No RPTR Wrap Around occurred on last Read<br>$1_B$ A RPTR Wrap Around occurred on last Read<br>Bit to be cleared by SW                                                                                                                                   |
| RMOD  | 15     | rw   | <b>Auto increment Read Mode</b><br>$0_B$ No increment RPTR on every Read<br>$1_B$ Auto increment RPTR on every Read                                                                                                                                                                              |

## 6.3 Functional Description

### 6.3.1 Enabling Protection

Protection has to be globally enabled per software, bit PM0.PROTEN implements this functionality, refer to chapter [Chapter 6.2.2](#).

### 6.3.2 Protection Levels

The bits PSW.PL1/0 select the current protection level, i.e the protection register set currently active. The decoding of PL1/0 is as follows:

**Table 6-3 Decoding of Protection Level**

| PL1 | PL0 | Protection Level   |
|-----|-----|--------------------|
| 0   | 0   | Protection Level 0 |
| 0   | 1   | Protection Level 1 |
| 1   | 0   | Protection Level 2 |
| 1   | 1   | Protection Level 3 |

## Memory Protection Unit (MPU)

PL1 and PL0 bits are mapped into PSW.10 and PSW.5 bits respectively. Note that due to the shared functionality implemented on the bit PSW.10, a write on this bit will be interpreted as a write on the PSW.PL1 only when the MPU is itself enabled (PM0.PROTN is 1). When the MPU is not enabled a write on this bit will be interpreted as a write on the HLDEN flag. For consistency, the flag PSW.PL0 is handled in a similar way, a write on PSW.PL0 is only effective when the MPU is enabled.

### 6.3.2.1 Protection Level 0

For the protection mechanism to work properly, the MPU has to be operated under a kind of privileged mode, programming and changing the protection information should only be allowed during this mode. Even if the C166 family architecture does not support directly this operation mode (only the one associated to the initialization phase ended by the EINIT execution), the privileged mode can be defined in this context as the mode entered when the processor runs with protection Level 0. This is the level entered after reset and the level automatically entered after an interrupt/trap is taken. Level 0 should be then the level used by the operating system, software kernel or the software components needing access to the whole system resources (specially to system control registers and peripheral area).

But note that defining and programming address ranges and permissions is still needed for Level 0 (even if it is the whole space). Per default (i.e. after reset), no access in any address range is allowed, also not for this level.

*Note: The need to program Level 0 allows in special occasions to give restricted access also to this level. Restriction sometimes needed to probe reliability of the software running under this level.*

### 6.3.3 Intersecting Memory Ranges

The permission to access a memory location is the OR of the memory range permissions. When two or more ranges intersect, the intersecting region has the permission of the most permissive range.

### 6.3.4 Protection of the MPU registers

As mentioned in [Chapter 6.3.2.1](#), the MPU registers need to be protected. A protection mechanism comes automatically with the use of the MPU and the fact that the whole address space, including SFRs, is under control of the MPU, see also [Chapter 6.3.5](#). Once protection is enabled, changing protection information can then only be performed from a protection level which has access to the corresponding SFR area (i.e. to the protection registers).

In addition to this inherited protection mechanism, the protection control registers are also EINIT protected. The EINIT protection creates some overhead during dynamic re-programming, however it adds an additional protection level that may be needed in case

## Memory Protection Unit (MPU)

different software component need to be executed at the same protection level (the one having access to these control registers -usually level 0-).

### 6.3.5 Accessing SFRs and GPRs

Once the protection system is activated, a task is not free anymore to access per software any special function register (SFR) unless this is explicitly covered by the address ranges and permissions assigned to this task. This applies to the internal IO area (SFR, ESFR, XSFR) and also to the external IO area (on chip LXBus peripherals or external peripherals). Since the minimum granularity of the address ranges is 256 bytes, the IO space is partitioned into blocks. A task will have access either to one of these blocks with its full set of registers or to none. For example the SFR/ESFR area (1 Kbyte), is divided into four blocks (F000h...F0FFh, F100h...F1FFh, FE00h...FEFFh, FF00h...FFFFh). For the XSFRs area, 4 Kbyte, the space is divided in 16 blocks.

CSFRs are also handled by the protection scheme, but exceptions are required for those CSFRs that are user registers. CSFR that are kept under the protection scheme are:

- PSW (partly), CPUCON1/2, CP, CSP, SP, SPSEG, STKUN, STKOV, TFR, VECSEG.

The USR0/1 bits of PSW, that are user bits, are excluded from the protection scheme. Also the PSW condition flags are excluded. Instructions like JBC/JNBS on the PSW conditions flags can then still be used in user mode. Read accesses to all the PSW fields are allowed.

CSFR that are excluded from the protection mechanism are:

- DPP0/1/2/3, MDL, MDH, MSW, MDC, MAH, MAL, MRW, MCW, QR0/1, QX0/1, IDX0/1, ZEROS, ONES, CPUID.

The DPP registers are handled as user registers to support its re-programming during run time (practice needed for code optimization purposes). When used in this way, it will be responsibility of the software to ensure their right handling, for example saving and restoring them in task switches. CPUID is not strictly a user register, however it is not required to define it as protected since it is anyhow not writable.

GPRs are excluded from the memory protection mechanism. Protection on the DPRAM is however guaranteed since the CP itself is protected. Similarly, GPRs mapped into the Local Register Banks are excluded from the protection mechanism.

### 6.3.6 Interrupts and PECs Handling

Any interrupt taken by the CPU will switch automatically the protection level to 0. This is valid for peripheral interrupts, debugger interrupts, hardware and software traps. As a consequence Interrupt Service Routines (ISRs) are always started with protection level 0, having usually access to all the system resources. The ISR itself can afterwards reduce the protection level and execute user code with protection restrictions.

## Memory Protection Unit (MPU)

Interrupt requests can be also serviced through PEC transfers, that is, fast data transfers between two memory locations. PEC transfers will be executed by the CPU without protection. Protection can still be ensured through the programming of the PEC control registers that should be only performed under the right protection level, usually in privileged mode (i.e. protection level 0). At the configuration time the software should then check for the correctness of the PEC source and destination pointers (according to the permissions allowed) and the PEC control register. Special care has to be taken when using continuous mode, in this case the software can not take care at the configuration time if the PEC will not violate an area in the future. Additional run time checks may be needed to support this mode (executed by the privileged software) or this mode will have to be avoided.

### 6.3.7 Special handling of RETI instruction

The PSW and specially the Protection Level selection flags (PSW.PL0/1) are handled under the protection scheme: explicit writes on the PSW are detected by the hardware and checked if they are triggered under the right protection level. In case the access is not allowed, a trap will be generated and the modification of the PSW will be avoided by the protection logic.

But the PSW can also be modified implicitly by the hardware and this hardware update can hardly be managed by the protection logic. Hardware updates on the PSW.PL0/1 field are triggered by the execution of a RETI instruction. These PSW hardware updates are in principle not critical as long as the PSW (and PSW.PL0/1) value that is taken from the Stack has not been manipulated by any user code. But since there is no possibility to prohibit user code from this possible manipulations (user code may make use of local stacks with write access to it) the only work around is to prohibit un-trusted user code from using the RETI instruction. RETI will be then specially handled as a kind of protected instruction that can only be executed when the protection level 0. This handling is consistent with the fact that interrupts are handled under protection level 0, returning from interrupts should then also be performed under the same level.

### 6.3.8 Context Switch operations

The Context Switch mechanism is executed in the core with the help of internal instructions that are auto-injected in the pipeline. Usually auto-injected instructions should run with the same protection level as the instruction causing the auto injection. However, due to the fact that the context switch is an interruptible operation and its completion may be delayed in certain situations, these context switch auto injected instructions have to be executed without considering protection. That means, while they are executed, the protection checks are not performed and/or are ignored. As a consequence only the CP update operation, that is not performed by the auto-injected instruction but by the context switch instruction itself, is performed under the protection scheme. The saving procedure of registers into DPRAM or the read of GPRs from

## Memory Protection Unit (MPU)

DPRAM is not performed under the protection scheme. DPRAM protection in this case will have to be ensured, in case it is needed, by the software, the software can check if the region addressed by the values programmed into CP are allowed.

### 6.3.9 Debugger Access Permissions

The debugger must be able to access all the memory space even if memory protection is active, this includes also the IO space (i.e. SFRs). The OCDS/Cerberus implements basically 2 mechanisms for accessing the system resources:

- triggering the CPU to execute a Monitor Routine that contains the code to access the resources (Call a Monitor)
- Injecting any instruction that can by itself access any resource

When using the first mechanism, that is started by the injection of an ITRAP instruction, the debugger will automatically run in privileged mode, i.e. with protection level 0. As defined in [Chapter 6.3.2.1](#), this is the level automatically entered after an interrupt (in this case after the injection of the debug TRAP instruction).

When using the second mechanism (also if the CPU is halted) the injected instruction will run without protection. The CPU keeps track of the fact that an instruction was injected by the Debugger and disables the protection check for that instruction.

With respect to accessing OCDS/Cerberus/MCDS SFRs by the debugger it just needs to be ensured that the debug monitor (used to program the debug logic) can access these registers with minimum overhead and without any impact on the user code. Since the debug monitor routine will always be executed with protection level 0, it is expected that all the memory space is then allowed. Also accessing these registers via injecting instructions can be performed without restrictions as explained above.

### 6.3.10 Invalid Access Traps

If an access is performed in a protected area an invalid access trap will be generated. Three traps are defined for this purpose:

MPR Memory Protection, Read

MPW Memory Protection, Write

MPX Memory Protection, Execute

They are defined as Class B traps. They are mapped to TFR.10,9,8 respectively (MPR is TFR.10, MPW is TFR.9 and MPX is TFR.8). Refer to the Hardware Traps description chapter for the complete description of the TFR register.

Note that no trap must be performed on accesses that are performed speculatively, this is why these traps can just be generated when it is known that the instruction is not cancelled anymore (this is, when the instruction goes into the Execute stage).

## Memory Protection Unit (MPU)

The already existing trap PRTFLT Protection Fault Trap is also used to indicate the execution of a RETI instruction from a protection level different to 0. Even when RETI causes a protection fault trap, it is normally executed.

### 6.3.10.1 Cancelling operations

Instructions causing a protection violation will be detected by the MPU but its full execution can not be suppressed, only the writes operations causing a protection fault or derived from an instruction causing a protection fault will be cancelled. Read operations can not be cancelled since they are triggered very soon in the pipeline (sometimes speculatively), however, the read data will not be written by the corresponding instruction in any memory mapped address.

There are some exceptions to the above general rule of cancelling writes operations, in particular, for instructions performing 2 write operations sometimes the first write can not be cancelled. These are the concrete cases:

- SCXT instruction. The write into the Stack can not be avoided when a Read protection violation on the mem operand is detected (for SCXT reg, mem) or a Write protection violation on the reg operand.
- CALLS, PCALL instruction. The first write into the Stack (CSP, or reg in case of PCALL) can not be avoided when a Write protection violation on the second Stack address is detected (where the IP should be pushed). This situation assumes that the Stack has grown over the limit of an allowed area right while executing this instruction (first stack push in an allowed area, second stack push in a non-allowed area).

As a consequence of the fact that Read operations can not be cancelled, destructive reads on the IO space can be still performed even if the MPU detects a protection violation.

As a consequence of the fact that Execute operations can not be cancelled, system instructions and their corresponding actions may be still executed even if they trigger an Execute protection violation. For example an IDLE instruction may still put the CPU in idle mode before the corresponding hardware trap routine can be executed (once the idle mode is left).

## 6.4 Initializing and using the MPU

### 6.4.1 Installing Protection

This chapter describes briefly the SW sequences needed for initializing and using the protection system. It also analyses the overhead created (real time performance). The implementation with 12 ranges is analyzed.

The initialization sequence that can be used for installing protection is:

## Memory Protection Unit (MPU)

- Disable Protection in case it is not (after reset protection is disabled), 1 write into PM0.
- Program the Range Registers, 1 PRA write, 24 writes into PRD (absolute maximum value, assumes that all ranges are used).
- Program Protection Mode Registers, 6 PMx writes.
- Enable protection, 1 write into PM0. This last write can be performed together with the write into the PM0 above, but in this case care should be taken to write this register at the end.

When the applications or software components using different protection levels can exactly be mapped to the protection sets implemented, this code sequence would set up the system and no additional overhead when using the MPU would exist during run time. After the initialization phase, whenever a change in the protection level is needed, the corresponding protection set has to be selected (changing PSW.PL). This is the only additional operation during run time.

This initialization, and in general any change in the protection registers, should be performed always having the protection disabled and usually will be executed from protection level 0. Note that in cases where the protection configuration and its activation needs to be immediately seen, the software has to take care that the latest write activating the protection is effective before executing the next affected instruction (by reading for example the latest written register). This is because as explained in [Chapter 6.2.2](#), there is no hardware mechanism to flush the pipeline when the protection is activated.

In case the protection needs can not be mapped into the implemented protection sets, some re-programming during run time is needed. The worst case scenario is that the ranges have to be re-programmed, then a sequence similar to the one during the initialization is needed. However it may be that only some already defined Ranges needs to be activated/deactivated, in this case only the Protection Mode Registers will need to be re-programmed. This assumes that at every moment it is known which ranges are used, so the PSW.PL1/0 has to be read before deciding what to change. An additional overhead during reprogramming is coming from the EINIT protection. After EINIT execution, reprogramming of the PMU registers is only allowed by releasing temporarily this protection by going to an unprotected mode (a command sequence of 4 write instructions with the use of a password is needed for that). After the re-programming the EINIT-protection has to be of course restored (again a command sequence of 4 write instructions). Note that reprogramming of protection registers that are currently not active (i.e. selected through PSW.PL) and do not become active through the reprogramming, is still possible without having to disable protection.

### 6.4.2 Changing Protection Level

Special care has to be taken when changing the protection level by writing explicitly into PSW. This is because any write into PSW takes effect immediately. If the privileged code

## Memory Protection Unit (MPU)

handling protection would write into the PSW before performing a code/task switch, the level of the privileged code would be itself changed and eventually the code/task switch (function call for example) couldn't be performed. For avoiding this immediate effect when writing into the PSW some tricks have to be used: stack manipulation and calling functions using the RETI/RETP instructions. The value of the new PSW with the new protection level has to be then stored in the stack, instead of writing the PSW explicitly. The RET instruction will then update the PSW associated to the new task with the correct protection level and at the right time.

### 6.4.3 Executing privileged code from non-privileged one

It is possible for a non-privileged (un-trusted) software to invoke a privileged software component (trusted). The non-privileged part has to give control to a privileged part, this can be performed by executing a software TRAP instruction. Automatically this instruction will change the protection level to 0. This mechanism allows for example invoking low level drivers from an application software and also returning from the user part of an ISR to the ISR itself, i.e. to the part handle by the OS or software kernel.

### 6.4.4 Fast task switches

Any task switch that is not controlled by the OS or software kernel will be handled as a trusted task with respect to the software that is invoking it. This is because if the switch is not performed under a software running with enough protection level (usually level 0), there is no possibility to change the protection level explicitly for this task.

### 6.4.5 Register Bank Selection

Since PSW.BANK field is now handled within the protection scheme, the register bank selection (global or local 1/2) will have to be settled by the software running with enough access permissions, i.e. enough protection level (usually level 0). The bank selection should then be done in the part of the ISR running on level 0 (starting level of all ISRs).

### 6.4.6 Debugger Use Cases

This chapter documents how to debug the system when memory protection is in use.

The following 4 use cases are identified:

- user wants to find the reason for a MPU trap
- user wants to debug the MPU trap routine
- user doesn't want to debug, he just wants to poll a variable with Cerberus
- user wants to debug without any irregular influence from the protection system

For the first use case, the standard debugging resources (OCDS) can be used for setting an IP breakpoint on the ISR/s handling the trap. Once there, it will be known which access type causes the trap, either implicitly because there are different trap routines

## Memory Protection Unit (MPU)

depending on the exception type or explicitly by reading the TFR flags. Also the protection level causing the violation can be obtained by reading the stacked PSW. With respect to the IP causing the trap, there is no direct access to it but to the linear following one, that is also stored in the stack.

The second use case, i.e. the debugging of the MPU trap routine, can be done similarly to the debugging of any trap routine and will be started probably also by setting an IP breakpoint on the corresponding ISR.

With respect the third use case, the variable polling action can be performed at any time independently of if the MPU is enabled or not. The debugger has always access to all the system resources even if the MPU is enabled.

The fourth use case, i.e. debugging without influence from the PMU, can be covered by disabling explicitly the MPU (PM0.PROTEN) via the debugger. Since the debugger does not know when the application will enable the MPU after the reset of the system, the debugger will have to monitor the status of the MPU (PMU0.PROTEN) and re-disable it once enabled. This use case is however rather strange because debugging is intended to be done with the real system behavior, if an application causes a MPU exception, this should also be seen during debugging.



## 7 Interrupt and Exception Control

The architecture of the XC27x5X supports several mechanisms for fast and flexible response to service requests from various sources internal or external to the micro controller. Different kinds of exceptions are handled in a similar way:

- Interrupts generated by the Interrupt Controller (ITC)
- DMA transfers issued by the Peripheral Event Controller (PEC)
- Traps caused by the TRAP instruction or issued by faults or specific system states

### Normal Interrupt Processing

The CPU temporarily suspends the current program execution and branches to an interrupt service routine in order to service an interrupt requesting device. As a result, the current program status (IP, PSW, and, in segmentation mode, also CSP) is saved on the system stack. A prioritization scheme with sixteen priority levels specifies the execution order of multiple interrupt requests.

### PEC Interrupt Processing

A faster alternative to normal interrupt processing is the use of the XC27x5X's integrated **Peripheral Event Controller** (PEC) to service an interrupt requesting device. Triggered by an interrupt request, the PEC performs a single word or byte data transfer between any two memory locations. During a PEC transfer, the normal program execution of the CPU is interrupted only for the data transfer. No internal program status information needs to be saved. The same prioritization scheme is used for PEC service as for normal interrupt processing.

### Trap Functions

**Trap Functions** are activated in response to special conditions that occur during the execution of instructions. A trap can also be caused externally by the External Service Request pins ESRx (e.g. used to implement NMI like behavior). Several hardware trap functions are provided for handling erroneous conditions and exceptions that arise during the program execution. Hardware traps always have highest priority and cause immediate system reaction. The software trap function is invoked by the TRAP instruction that generates a software interrupt for a specified interrupt vector. For all types of traps, the current program status is saved on the system stack.

### External Interrupt Processing

The XC27x5X does not provide dedicated external interrupt input pins but rather allows to configure a subset of its input pins as interrupt inputs. Interrupt (trap) input pins can be chosen from standard inputs or External Service Request pins ESRx. The available options are detailed in the **External Interrupts** section.

## Interrupt and Exception Control

### Interrupt Sources and Routing

To activate and correctly route an interrupt source programming of the following on-chip components must be considered:

- Interrupt control of each peripheral
- IMB memory controller **Interrupt Generation**
- SCU **External Request Unit (ERU)**
- **SCU Interrupt Generation**

Additionally the port programming must be considered if external interrupt sources are to be used.

## 7.1 Interrupt System Structure

The XC27x5X provides 96 separate interrupt nodes assignable to 16 priority levels, with 8 sub-levels (group priority) on each level. In order to support modular and consistent software design techniques, most sources of an interrupt or PEC request are supplied with a separate interrupt control register and an interrupt vector. The control register contains the interrupt request flag, the interrupt enable bit, and the interrupt priority of the associated source. Each source request is then activated by one specific event, determined by the selected operating mode of the respective device. For efficient resource usage, multi-source interrupt nodes are also incorporated. These nodes can be activated by several source requests, such as by different kinds of errors in the serial interfaces. However, specific status flags which identify the type of error are implemented in the respective peripheral control registers. Additional sharing of interrupt nodes is supported via [Interrupt Node Sharing](#).

The XC27x5X provides a vectored interrupt system. In this system specific vector locations in the memory space are reserved for the reset, trap, and interrupt service functions. Whenever a request occurs, the CPU branches to the location that is associated with the respective interrupt source. The Class B hardware traps all share the same interrupt vector. The status flags in the Trap Flag Register (TFR) can then be used to determine which exception caused the trap. For the special software TRAP instruction, the vector address is specified by the operand field of the instruction, which is a seven bit trap number.

The reserved vector locations build a jump table in the low end of a segment (selected by register VECSEG) in the XC27x5X's address space. The jump table consists of the appropriate jump instructions which transfer control to the interrupt or trap service routines and which may be located anywhere within the address space. The entries of the jump table are located at the lowest addresses in the selected code segment. Each entry occupies 2, 4, 8, or 16 words (selected by bitfield VECSC in register CPUCON1), providing room for at least one double word instruction. The respective vector location results from multiplying the trap number by the selected step width ( $2^{(VECSC+2)}$ ).

All pending interrupt requests are arbitrated. The arbitration winner is indicated to the CPU together with its priority level and action request. The CPU triggers the corresponding action based on the required functionality (normal interrupt, PEC, jump table cache, etc.) of the arbitration winner.

An action request will be accepted by the CPU if the requesting source has a higher priority than the current CPU priority level and interrupts are globally enabled. If the requesting source has a lower (or equal) interrupt level priority than the current CPU task, it remains pending.

## Interrupt and Exception Control



Figure 7-1 Block Diagram of the Interrupt and PEC Controller

## Interrupt and Exception Control

### 7.2 Interrupt Arbitration

The XC27x5X interrupt arbitration system can handle interrupt requests from up to 96 sources. Interrupt requests may be triggered either by the internal peripherals or by external inputs. The “End of PEC” interrupt for supporting enhanced PEC functionality is connected internally to one of the interrupt request lines.

The arbitration process starts with an enabled interrupt request and stays active for as long as an enabled interrupt request is pending.

Each interrupt request line is controlled by its interrupt control register xxIC (here and below xx stands for the mnemonic of the respective interrupt source). An interrupt request event sets the interrupt request flag in the corresponding interrupt control register (bit xxIC.IR). The interrupt request can also be triggered by the software if the program sets the respective interrupt request bit.

If the request bit has been set and this interrupt request is enabled by the interrupt enable bit of the same control register (bit xxIC.IE), an arbitration cycle starts with the next clock cycle. However, if an arbitration cycle is currently in progress, the new interrupt request will be delayed until the next arbitration cycle. If an interrupt request (or PEC request) is accepted by the core, the respective interrupt request flag is cleared automatically.

All interrupt requests pending at the beginning of a new arbitration cycle are considered simultaneous. Within the arbitration cycle, the arbitration is independent of the actual request time.

The XC27x5X uses a three-stage interrupt prioritization scheme for interrupt arbitration as shown in [Figure 7-2](#).

## Interrupt and Exception Control


**Figure 7-2    Interrupt Arbitration**

The first arbitration stage compares the priority levels of interrupt request lines. The priority level of each requestor consists of interrupt priority level and group priority level. An interrupt priority level is programmed for each interrupt request line by the 4-bit bitfield ILVL of respective xxIC register. The group priority level is programmed for each interrupt request line by the 2-bit bitfield GLVL and the extension bit GPX of the register xxIC. Both together, GPX and GLVL form the 3-bit (extended) group priority level XGLVL, controlling up to eight interrupt sub-priorities within one of the 16 interrupt levels.

*Note: All interrupt request sources that are enabled and programmed to the same interrupt priority level (ILVL) must have different group priority levels. Otherwise, an incorrect interrupt vector may be generated.*

The second arbitration stage compares the priority of the first stage winner with the priority of OCDS service requests. OCDS service requests bypass the first stage of arbitration and go directly to the CPU Action Control Unit. The CPU Action Control Unit disregards the group priority level of interrupt/PEC requests and deals only with interrupt priority levels (ILVL). To compare with OCDS service request priority programmed by 5-bit value, the 4-bit ILVL of the interrupt/PEC request is extended to a 5-bit value with MSB equal to 0. This means that any OCDS request with MSB=1 will always win the second stage arbitration. However, if there is an OCDS request with MSB=0 conflicting with the same priority interrupt/PEC request, the latter is sent to the CPU.

## Interrupt and Exception Control

On the third arbitration stage, the priority level of the second stage winner is compared with the priority of the current CPU task. An action request will be accepted by the CPU if the requesting source has a higher priority level than the current CPU priority level (bits ILVL of the PSW register) and interrupts are globally enabled by the global interrupt enable flag IEN in PSW. The CPU denies all requests in case of a cleared IEN flag. To compare with the 5-bit priority level of the second stage winner, the 4-bit ILVL.PSW is extended to a 5-bit value with MSB equal to 0. This means that any request with MSB=1 will always win the arbitration against any CPU level. If the requester has a lower or equal priority level than current CPU task, the request stays pending.

*Note: Priority level  $0000_B$  is the default level of the CPU. Therefore, a request on interrupt priority level  $0000_B$  will be arbitrated, but the CPU will never accept an action request on this level. However, every enabled interrupt request (including a denied interrupt request and a priority level  $0000_B$  request) triggers a CPU wake-up from idle state independent of setting the global interrupt enable bit PSW.IEN.*

## Interrupt and Exception Control

### 7.3 Interrupt Control

All interrupt control registers are organized identically. The lower nine bits of an interrupt control register contain the complete interrupt control and status information of the associated source required during one round of prioritization (arbitration cycle). The upper seven bits of the respective register are reserved. All interrupt control registers are bit addressable and all control bits can be read or written via software. Therefore, each interrupt source can be programmed or modified with just one instruction. In the case of reading the interrupt control registers with instructions that operate with word data types, the upper 7 bits (15...9) will return zeros. It is recommended to always write zeros to these bit positions.

The IR bit of any IC register is of type “rwh” and is set by hardware upon occurrence of an interrupt. If the software requires to write to the IC register while the interrupt source is enabled the software write may conflict with a hardware access to bit IR. To address this conflict scenario all xxIC registers are located in the bit addressable memory area. The use of C166 bit modification instructions is therefore possible and recommended. These instructions provide a special “protection mask” feature which allows to protect IR bit from unintended software write. Refer to CPU Bit Manipulation Unit chapter for details.

The layout of the interrupt control registers shown below is applicable to all xxIC registers.

#### **xxIC**

#### **Interrupt Control Register**

**(E)SFR (xxxx<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7  | 6  | 5 | 4    | 3 | 2 | 1    | 0 |
|----|----|----|----|----|----|---|-----|----|----|---|------|---|---|------|---|
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | GPX | IR | IE |   | ILVL |   |   | GLVL |   |

| Field | Bits | Type | Description                                                                                                                                                                             |
|-------|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GPX   | 8    | rw   | <b>Group Priority Extension</b><br>Defines the value of high-order group level bit                                                                                                      |
| IR    | 7    | rwh  | <b>Interrupt Request Flag</b><br>0 <sub>B</sub> No request pending<br>1 <sub>B</sub> This source has raised an interrupt request                                                        |
| IE    | 6    | rw   | <b>Interrupt Enable Control Bit</b><br>(individually enables/disables a specific source)<br>0 <sub>B</sub> Interrupt request is disabled<br>1 <sub>B</sub> Interrupt request is enabled |

## Interrupt and Exception Control

| Field | Bits   | Type | Description                                                                                             |
|-------|--------|------|---------------------------------------------------------------------------------------------------------|
| ILVL  | [5:2]  | rw   | <b>Interrupt Priority Level</b><br>$F_H$ Highest priority level<br>.....<br>$0_H$ Lowest priority level |
| GLVL  | [1:0]  | rw   | <b>Group Priority Level</b><br>$3_H$ Highest priority level<br>...<br>$0_H$ Lowest priority level       |
| 0     | [15:9] | r    | <b>Reserved</b><br>read as 0; should be written with 0.                                                 |

When accessing interrupt control registers through instructions which operate on word data types, their upper 7 bits (15 ... 9) will return zeros when read, and will discard written data. It is recommended to always write zeros to these bit positions.

The **Interrupt Request Flag** is set by hardware whenever a service request from its respective source occurs. It is cleared automatically upon entry into the interrupt service routine or upon a PEC service. In the case of PEC service, the Interrupt Request flag remains set if the COUNT field in register PECCx of the selected PEC channel decrements to zero and bit EOPINT is cleared. This allows a normal CPU interrupt to respond to a completed PEC block transfer on the same priority level.

*Note: Modifying the Interrupt Request flag via software causes the same effects as if it had been set or cleared by hardware.*

The **Interrupt Enable Control Bit** determines whether the respective interrupt node takes part in the arbitration process (enabled) or not (disabled). The associated request flag will be set upon a source request in any case. The occurrence of an interrupt request can so be polled via xxIR even while the node is disabled.

*Note: In this case the interrupt request flag xxIR is not cleared automatically but must be cleared via software.*

### 7.3.1 Interrupt Priority Level and Group Level

The four bits of bitfield ILVL specify the priority level of a service request for the arbitration of simultaneous requests. The priority increases with the numerical value of ILVL: so,  $0000_B$  is the lowest and  $1111_B$  is the highest priority level.

When more than one interrupt request on a specific level becomes active at the same time, the values in the respective bitfields GPX and GLVL are used for second level arbitration to select one request to be serviced. Again, the group priority increases with the numerical value of the concatenation of bitfields GPX and GLVL, so  $000_B$  is the lowest and  $111_B$  is the highest group priority.

## Interrupt and Exception Control

**Note:** All interrupt request sources enabled and programmed to the same priority level must always be programmed to different group priorities. Otherwise, an incorrect interrupt vector will be generated.

Upon entry into the interrupt service routine, the priority level of the source that won the arbitration and whose priority level is higher than the current CPU level, is copied into bitfield ILVL of register PSW after pushing the old PSW contents onto the stack.

The interrupt system of the XC27x5X allows nesting of up to 15 interrupt service routines of different priority levels (level 0 cannot be arbitrated).

Interrupt requests programmed to priority levels 15 ... 8 (i.e., ILVL = 1XXX<sub>B</sub>) can be serviced by the PEC if the associated PEC channel is properly assigned and enabled (please refer to [Section 7.10.4](#)). Interrupt requests programmed to priority levels 7 through 1 will always be serviced by normal interrupt processing.

### 7.3.2 General Interrupt Control Functions in Register PSW

The acceptance of an interrupt request depends on the current CPU priority level (bitfield ILVL in register PSW) and the global interrupt enable control bit IEN in register PSW (see [Section 5.8](#)).

**CPU Priority ILVL** defines the current level for the operation of the CPU. This bitfield reflects the priority level of the routine currently executed. Upon entry into an interrupt service routine, this bitfield is updated with the priority level of the request being serviced. The PSW is saved on the system stack before the request is serviced. The CPU level determines the minimum interrupt priority level which will be serviced. Any request on the same or a lower level will not be acknowledged. The current CPU priority level may be adjusted via software to control which interrupt request sources will be acknowledged. PEC transfers do not really interrupt the CPU, but rather “steal” a single cycle, so PEC services do not influence the ILVL field in the PSW.

Hardware traps switch the CPU level to maximum priority (i.e. 15) so no interrupt or PEC requests will be acknowledged while an exception trap service routine is executed.

**Note:** The TRAP instruction does not change the CPU level, so software invoked trap service routines may be interrupted by higher requests.

**Interrupt Enable bit IEN** globally enables or disables PEC operation and the acceptance of interrupts by the CPU. When IEN is cleared, no new interrupt requests are accepted by the CPU. When IEN is set to 1, all interrupt sources, which have been individually enabled by the interrupt enable bits in their associated control registers, are globally enabled. Traps are non-maskable and are, therefore, not affected by the IEN bit.

**Note:** To generate requests, interrupt sources must be also enabled by the interrupt enable bits in their associated control register.

## Interrupt and Exception Control

**Register Bank Select bitfield BANK** defines the currently used register bank for the CPU operation. When the CPU enters an interrupt service routine, this bitfield is updated to select the register bank associated with the serviced request:

- Requests on priority levels 15 ... 12 use the register bank pre-selected via the respective bitfield GPRSELx in the corresponding BNKSEL register
- Requests on priority levels 11 ... 1 always use the global register bank, i.e. BANK = 00<sub>B</sub>
- Hardware traps always use the global register bank, i.e. BANK = 00<sub>B</sub>
- The TRAP instruction does not change the current register bank

### 7.3.3 Selective Interrupt Disabling

Interrupt requests may be temporarily disabled and enabled during the execution of the software. This may be required to exclude specific interrupt sources based on the current status of the application. In particular, this is necessary to achieve a deterministic execution of time-critical code sequences.

Interrupt requests in the XC27x5X can be disabled and enabled on three different levels:

- Disable all interrupt requests for a certain code sequence
- Disable all interrupt requests globally
- Disable single interrupt requests

The **ATOMIC** and **EXTend** instructions automatically disable all interrupt requests for the duration of the following 1 ... 4 instructions. This is useful for semaphore handling, for example, and does not require to re-enable the interrupt system after the inseparable instruction sequence.

**Global interrupt control** is achieved with a single instruction:

```
BCLR IEN ;Clear IEN flag (causes pipeline restart)
```

**Specific interrupt control** is achieved by controlling the enable bits in the associated interrupt control registers.

```
BCLR T2IE ;Clear enable flag to disable intr.node
```

Due to pipeline effects, however, an interrupt request may be executed after the corresponding node was disabled, if the request coincides with clearing the enable flag.

If the application must avoid this, the following sequence can be used, ensuring that no interrupt requests from this source will be serviced after disabling the interrupt node:

```
BCLR IEN ;Globally disable interrupts
BCLR T2IE ;Disable Timer 2 interrupt node
JNB T2IE, Next ;Any instruction reading T2IC can be used
Next:          ;(assures that T2IC is written by BCLR
               ;before being read by JNB or other instr.)
BSET IEN     ;Globally enable interrupts again
```

## Interrupt and Exception Control

Please note that the sequence above blindly controls the global enable flag. If the global setting must not be changed, the code sequence can be enhanced, as shown below:

```
JNB IEN, GlobalIntOff
BCLR IEN           ;Globally disable interrupts
BCLR T2IE          ;Disable Timer 2 interrupt node
JNB T2IE, Next     ;Any instruction reading T2IC can be used
Next:              ;(assures that T2IC is written by BCLR
                  ;before being read by JNB or other instr.)
BSET IEN           ;Globally enable interrupts again
JMPR cc_uc, Continue
GlobalIntOff:      ;Interrupts are globally disabled anyway
BCLR T2IE          ;Disable Timer 2 interrupt node

JNB T2IE, Continue ;Reading T2IC can be omitted if the next
Continue:          ;few instructions do not set IEN
...
```

The same function can easily be implemented as a C macro:

```
#define Disable_One_Interrupt(IE_bit) \
{if(IEN) {IEN=0; IE_bit=0; while (IE_bit); IEN=1;} else
{IE_bit=0; while IE_bit);}
Usage Example:
Disable_One_Interrupt(T2IE) ; // T2 interrupt enable flag
```

ATOMIC or EXTend sequences preserve the status of the interrupt arbitration when they begin. An accepted request is processed after the ATOMIC/EXTend sequence. Therefore, the following code sequence may not produce the desired result:

```
AvoidThis:
ATOMIC #3
NOP
BCLR T2IE          ;Disable Timer 2 interrupt node
NOP              ;Timer 2 request may be processed
                  ;after this instruction!!!
```

### 7.3.4 Interrupt Class Management

An interrupt class covers a set of interrupt sources with the same importance, i.e. the same priority from the system's viewpoint. Interrupts of the same class must not interrupt each other. The XC27x5X supports this function with two features:

- **Classes with up to eight members** can be established by using the same interrupt priority (ILVL) and assigning a dedicated group level to each member. This functionality is built-in and handled automatically by the interrupt controller.

## Interrupt and Exception Control

- **Classes with more than eight members** can be established by using a number of adjacent interrupt priorities (ILVL) and the respective group levels (eight per ILVL). Each interrupt service routine within this class sets the CPU level to the highest interrupt priority within the class. All requests from the same or any lower level are blocked now, i.e. no request of this class will be accepted.

The example shown below establishes 3 interrupt classes which cover 2 or 3 interrupt priorities, depending on the number of members in a class. A level 6 interrupt disables all other sources in class 2 by changing the current CPU level to 8, which is the highest priority (ILVL) in class 2. Class 1 requests or PEC requests are still serviced, in this case.

In this way, the interrupt sources (excluding PEC requests) are assigned to 3 classes of priority rather than to 7 different levels, as the hardware support would do.

**Table 7-1 Software Controlled Interrupt Classes (Example)**

| ILVL<br>(Priority) | Group Level |   |   |   |   |   |   |   | Interpretation                              |
|--------------------|-------------|---|---|---|---|---|---|---|---------------------------------------------|
|                    | 7           | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                                             |
| 15                 |             |   |   |   |   |   |   |   | PEC service on up to 8 channels             |
| 14                 |             |   |   |   |   |   |   |   |                                             |
| 13                 |             |   |   |   |   |   |   |   |                                             |
| 12                 | X           | X | X | X | X | X | X | X | Interrupt Class 1<br>9 sources on 2 levels  |
| 11                 | X           |   |   |   |   |   |   |   |                                             |
| 10                 |             |   |   |   |   |   |   |   |                                             |
| 9                  |             |   |   |   |   |   |   |   |                                             |
| 8                  | X           | X | X | X | X | X | X | X | Interrupt Class 2<br>17 sources on 3 levels |
| 7                  | X           | X | X | X | X | X | X | X |                                             |
| 6                  | X           |   |   |   |   |   |   |   |                                             |
| 5                  | X           | X | X | X | X | X | X | X | Interrupt Class 3<br>9 sources on 2 levels  |
| 4                  | X           |   |   |   |   |   |   |   |                                             |
| 3                  |             |   |   |   |   |   |   |   |                                             |
| 2                  |             |   |   |   |   |   |   |   |                                             |
| 1                  |             |   |   |   |   |   |   |   |                                             |
| 0                  |             |   |   |   |   |   |   |   | No service!                                 |

## 7.4 Interrupt Vector Table

The XC27x5X provides a vectored interrupt system. This system reserves a set of specific memory locations, which are accessed automatically upon the respective trigger event. Entries for the following events are provided:

- Reset (hardware, software, watchdog)
- Traps (hardware-generated by fault conditions or via TRAP instruction)
- Interrupt service requests

Whenever a request is accepted, the CPU branches to the location associated with the respective trigger source. This vector position directly identifies the source causing the request, with the following exceptions:

- Class B hardware traps all share the same interrupt vector. The status flags in the Trap Flag Register (TFR) are used to determine which exception caused the trap. For details, see [Section 7.9](#).
- An interrupt node may be shared by several interrupt requests, e.g. within a module. Additional flags identify the requesting source, so the software can handle each request individually. For details, see [Section 7.14.2](#).
- The interrupt jump cache feature is used. For details, see [Section 7.5](#)

The reserved vector locations build a vector table located in the address space of the XC27x5X. The vector table usually contains the appropriate jump instructions that transfer control to the interrupt or trap service routines. These routines may be located anywhere within the address space. The location and organization of the vector table is programmable.

The Vector Segment register VECSEG defines the segment of the Vector Table (can be located in all segments, except for reserved areas).

Bitfield VECSC in register CPUCON1 defines the space between two adjacent vectors (can be 2, 4, 8, or 16 words). For a summary of register CPUCON1, please refer to [Section 5.4](#).

Each vector location has an offset address to the segment base address of the vector table (given by VECSEG). The offset can be easily calculated by multiplying the vector number with the vector space programmed in bitfield VECSC.

**Table 7-9** lists all sources capable of requesting interrupt or PEC service in the XC27x5X, the associated interrupt vector locations, the associated vector numbers, and the associated interrupt control registers.

*Note: Interrupt nodes which are not used by their associated modules or are not connected to a module in the actual derivative may be used to generate software controlled interrupt requests by setting the respective IR flag.*

## Interrupt and Exception Control

**VECSEG**
**Vector Segment Pointer**
**SFR(FF12<sub>H</sub>)**
**Reset Value: 00XX<sub>H</sub>**

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

r      r      r      r      r      r      r      r      rwh

| Field  | Bits   | Type | Description                                             |
|--------|--------|------|---------------------------------------------------------|
| VECSEG | [7:0]  | rwh  | <b>Segment number of the Vector Table</b>               |
| 0      | [15:8] | r    | <b>Reserved</b><br>read as 0; should be written with 0. |

The initial user value of register VECSEG is configured according to settings made for [Startup Configuration and Bootstrap Loading](#).

## Interrupt and Exception Control

### 7.5 Interrupt Jump Table Cache

The mechanism that uses the vector table location as the entry point for the interrupt service routines can be overwritten by the Interrupt Controller (ITC). For a very fast interrupt response time, the XC27x5X offers the Interrupt Jump Table Cache (also called “fast interrupt”). The ITC can transfer to the CPU a 24-bit vector which is directly used as a start address for the service routine. This feature skips the path through the vector table which normally saves the execution of at least one branch. Therefore, avoiding the vector table may significantly improve interrupt response time. However, the number of 24-bit vectors in the ITC is limited.

Fast interrupt is available for two interrupt sources with interrupt priority levels greater than or equal to 12. The Interrupt Jump Table Cache skips the instruction fetches from the interrupt vector table and executes a direct jump to the interrupt service routines entry point. This feature is controlled by a set of two interrupt jump table cache registers (FINTxCSP, FINTxADDR) for each of the two jump table entries.

Every interrupt jump table cache entry contains an enable bit, an associated arbitration priority level (ILVL and GLVL), and the 24-bit address of the interrupt service routine. Note that only the two lower bits of the interrupt priority level are selectable in the respective control registers. The two upper bits of the interrupt priority level are fixed to 11<sub>B</sub>, which limits the allowed interrupt priority level to be greater than or equal to 12.

#### FINT0CSP

##### Fast Interrupt Control 0

XSFR(EC00<sub>H</sub>)

Reset Value: 0000<sub>H</sub>

#### FINT1CSP

##### Fast Interrupt Control 1

XSFR(EC04<sub>H</sub>)

Reset Value: 0000<sub>H</sub>

| 15 | 14 | 13 | 12  | 11   | 10   | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2 | 1 | 0 |
|----|----|----|-----|------|------|---|---|---|---|---|---|-----|---|---|---|
| EN | 0  | 0  | GPX | ILVL | GLVL |   |   |   |   |   |   | SEG |   |   |   |

rw r rw rw

| Field | Bits | Type | Description                                                                                                                                                                                                                                                                                                                |
|-------|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EN    | 15   | rw   | <b>Fast Interrupt Enable</b><br>0 <sub>B</sub> The interrupt jump table cache is disabled.<br>No fast interrupt is used.<br>1 <sub>B</sub> The interrupt jump table cache is enabled. A fast interrupt (direct jump to the interrupt service routine) is used instead of the normal fetch from the interrupt vector table. |

## Interrupt and Exception Control

| Field       | Bits    | Type | Description                                                                                                                                                                                                                                                                                                                               |
|-------------|---------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>GPX</b>  | 12      | rw   | <b>Group Priority Extension</b><br>This bit together with bitfield GLVL selects the group priority level (XGLVL) of the associated interrupt jump table cache entry.                                                                                                                                                                      |
| <b>ILVL</b> | [11:10] | rw   | <b>Interrupt Priority Level</b><br>This bitfield selects the lower two bits of the interrupt priority level associated with this interrupt jump table cache entry.<br><i>Note: The two upper bits of the interrupt priority level are fixed to 11<sub>B</sub>, which ends in an interrupt priority level greater than or equal to 12.</i> |
| <b>GLVL</b> | [9:8]   | rw   | <b>Group Priority Level</b><br>This bitfield together with GPX-bit selects the group priority level (XGLVL) of the associated interrupt jump table cache entry.                                                                                                                                                                           |
| <b>SEG</b>  | [7:0]   | rw   | <b>Segment Number of Interrupt Service Routine</b><br>Address bits 23:16 of the interrupt service routine's entry point.                                                                                                                                                                                                                  |
| <b>0</b>    | [14:13] | r    | <b>Reserved</b><br>read as 0; should be written with 0.                                                                                                                                                                                                                                                                                   |

**FINT0ADDR**
**Fast Interrupt Address 0**
**XSFR (EC02<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**
**FINT1ADDR**
**Fast Interrupt Address 1**
**XSFR (EC06<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**


| Field       | Bits   | Type | Description                                                                                                      |
|-------------|--------|------|------------------------------------------------------------------------------------------------------------------|
| <b>ADDR</b> | [15:1] | rw   | <b>Address of Interrupt Service Routine</b><br>Address bits 15:1 of the interrupt service routine's entry point. |

## Interrupt and Exception Control

| Field | Bits | Type | Description                                                                                                                                                                              |
|-------|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | 0    | r    | <b>Interrupt Service Routine Address Bit 0</b><br>LSB of the interrupt service routine's entry point address. This address bit is always 0 because of the program code's word alignment. |

## Interrupt and Exception Control

### 7.6 CPU Status Saving

Before an interrupt request that has been arbitrated is actually serviced, the status of the current task is automatically saved on the system stack. The CPU status (PSW) is saved together with the location at which execution of the interrupted task is to be resumed after returning from the service routine. This return location is specified through the Instruction Pointer (IP) and, in the case of a segmented memory model, the Code Segment Pointer (CSP). Bit SGTDIS in register CPUCON1 controls how the return location is stored.

- The system stack receives the PSW first, followed by the IP (unsegmented), or followed by CSP and then IP (segmented mode). This optimizes the usage of the system stack if segmentation is disabled.
- The CPU priority field (ILVL in PSW) is updated with the priority of the interrupt request to be serviced, so the CPU now executes on the new level.
- The register bank select field (BANK in PSW) is changed to select the register bank associated with the interrupt request. The association between interrupt requests and register banks are partly pre-defined and can partly be programmed.
- The interrupt request flag of the source being serviced is cleared. IP and CSP are loaded with the vector associated with the requesting source, and the first instruction of the service routine is fetched from the vector location which is expected to branch to the actual service routine (except when the interrupt jump table cache is used). All other CPU resources, such as data page pointers and the context pointer, are not affected.

When the interrupt service routine is exited (RETI is executed), the status information is popped from the system stack in the reverse order, taking into account the value of bit SGTDIS.



Task Status saved on the System Stack

## Interrupt and Exception Control

### 7.7 CPU Context Switch

An interrupt service routine usually saves all the registers it uses on the stack and restores them before returning. To ease this process the XC27x5X allows switching the complete bank of CPU registers (GPRs) either automatically or with a single instruction, so that the service routine executes within its own separate context (see also [Section 5.5.2](#)).

There are two ways to switch context:

1. **Context switch on interrupt** automatically updates bitfield PSW.BANK to select one of the two local register banks or the current global register bank, so the service routine may now use its “own registers” directly. This local register bank is preserved when the service routine is terminated; thus, its contents are available on the next call. For interrupt priority levels 15 ... 12 the target register bank can be pre-selected. The register bank selection registers BNKSELx provide a 2-bit field for each priority level. The respective bitfield is then copied to bitfield BANK in register PSW to select the register bank, as soon as the respective interrupt request is accepted.
2. **Explicit context switch by software** is initiated by a write to CP or PSW registers.
  - a) A write to PSW.BANK bitfields allows to switch between global and local banks.
  - b) A write to CP allows to relocate the memory mapped global bank to another memory location.

For example the instruction “SCXT CP, #New\_Bank” pushes the contents of the context pointer (CP) on the system stack and loads CP with the immediate value “New\_Bank”. The new CP value sets a new global register bank. The service routine may now use its “own registers”. This global register bank is preserved when the service routine is terminated, i.e. its contents are available for the next call. Before returning (RETI), the previous CP simply be restored from the system stack using “POP CP”.

*Note: Other resources used by an interrupting program (like DPP registers) must be saved and restored separately.*

*Note: There are certain timing restrictions during context switching associated with pipeline behavior. For details, see [Section 5.5.2](#).*

## Interrupt and Exception Control

### 7.8 Fast Bank Switching

The interrupt handler supports an additional enhanced feature (compared to the C166 family) for normal interrupts called Fast Bank Switching. To speed up interrupt handling, the core can use fast General Purpose Register (GPR) bank switching for interrupts with an interrupt level greater or equal than 12. For every arbitration priority level with [ $ILVL = '15_D' - '12_D$  and  $XGLVL = '7_D' - '0_D'$ ], the register bank can be selected with two bits. The select-bits are located in the four register bank selection registers BNKSELx ( $x = 0 \dots 3$ ).

The following table identifies the arbitration priority level assignment to the respective bit fields within the four register bank selection registers:

**Table 7-2 Register Bank Assignment**

| <b>ILVL</b> | <b>XGLVL</b> | <b>Assigned GPRSELx Register</b> | <b>ILVL</b> | <b>XGLVL</b> | <b>Assigned GPRSELx Register</b> |
|-------------|--------------|----------------------------------|-------------|--------------|----------------------------------|
| 15          | 7            | BNKSEL3.GPRSEL7                  | 13          | 7            | BNKSEL2.GPRSEL7                  |
| 15          | 6            | BNKSEL3.GPRSEL6                  | 13          | 6            | BNKSEL2.GPRSEL6                  |
| 15          | 5            | BNKSEL3.GPRSEL5                  | 13          | 5            | BNKSEL2.GPRSEL5                  |
| 15          | 4            | BNKSEL3.GPRSEL4                  | 13          | 4            | BNKSEL2.GPRSEL4                  |
| 15          | 3            | BNKSEL1.GPRSEL7                  | 13          | 3            | BNKSEL0.GPRSEL7                  |
| 15          | 2            | BNKSEL1.GPRSEL6                  | 13          | 2            | BNKSEL0.GPRSEL6                  |
| 15          | 1            | BNKSEL1.GPRSEL5                  | 13          | 1            | BNKSEL0.GPRSEL5                  |
| 15          | 0            | BNKSEL1.GPRSEL4                  | 13          | 0            | BNKSEL0.GPRSEL4                  |
| 14          | 7            | BNKSEL3.GPRSEL3                  | 12          | 7            | BNKSEL2.GPRSEL3                  |
| 14          | 6            | BNKSEL3.GPRSEL2                  | 12          | 6            | BNKSEL2.GPRSEL2                  |
| 14          | 5            | BNKSEL3.GPRSEL1                  | 12          | 5            | BNKSEL2.GPRSEL1                  |
| 14          | 4            | BNKSEL3.GPRSEL0                  | 12          | 4            | BNKSEL2.GPRSEL0                  |
| 14          | 3            | BNKSEL1.GPRSEL3                  | 12          | 3            | BNKSEL0.GPRSEL3                  |
| 14          | 2            | BNKSEL1.GPRSEL2                  | 12          | 2            | BNKSEL0.GPRSEL2                  |
| 14          | 1            | BNKSEL1.GPRSEL1                  | 12          | 1            | BNKSEL0.GPRSEL1                  |
| 14          | 0            | BNKSEL1.GPRSEL0                  | 12          | 0            | BNKSEL0.GPRSEL0                  |

## Interrupt and Exception Control

**BNKSEL0**

 Register Bank Selection 0      XSFR(EC20<sub>H</sub>)      Reset Value: 0000<sub>H</sub>
**BNKSEL1**

 Register Bank Selection 1      XSFR(EC22<sub>H</sub>)      Reset Value: 0000<sub>H</sub>
**BNKSEL2**

 Register Bank Selection 2      XSFR(EC24<sub>H</sub>)      Reset Value: 0000<sub>H</sub>
**BNKSEL3**

 Register Bank Selection 3      XSFR(EC26<sub>H</sub>)      Reset Value: 0000<sub>H</sub>

| 15      | 14      | 13      | 12      | 11      | 10      | 9       | 8       | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---------|---------|---------|---------|---------|---------|---------|---------|---|---|---|---|---|---|---|---|
| GPRSEL7 | GPRSEL6 | GPRSEL5 | GPRSEL4 | GPRSEL3 | GPRSEL2 | GPRSEL1 | GPRSEL0 |   |   |   |   |   |   |   |   |

rw            rw

| Field                                                                                       | Bits                                                                              | Type | Description                                                                                                                                                                          |
|---------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GPRSEL0,<br>GPRSEL1,<br>GPRSEL2,<br>GPRSEL3,<br>GPRSEL4,<br>GPRSEL5,<br>GPRSEL6,<br>GPRSEL7 | [1:0],<br>[3:2],<br>[5:4],<br>[7:6],<br>[9:8],<br>[11:10],<br>[13:12],<br>[15:14] | rw   | <b>Register Bank Selection</b><br>00 <sub>B</sub> Global register bank<br>01 <sub>B</sub> Reserved<br>10 <sub>B</sub> Local register bank 1<br>11 <sub>B</sub> Local register bank 2 |

*Note: The GPRSELx value of the current triggered interrupt is automatically transferred into the Program Status Word (PSW).*

:

## 7.9 Trap Functions

The C166SV2 CPU supports software and hardware trap functions.

### 7.9.1 Software Traps

The TRAP instruction is used to cause a software call to an interrupt service routine. The trap number specified in the operand field of the trap instruction determines which vector location of the vector table will be used.

The TRAP instruction has an effect similar to an interrupt request at the same vector. PSW, CSP (in segmentation mode), and IP are pushed into the system stack and then a jump is taken to the specified vector location. When a software trap is executed, the CSP for the trap service routine is loaded with the value of the VECSEG register. No Interrupt Request flags are affected by the TRAP instruction. The interrupt service routine called by a TRAP instruction must be terminated with a RETI (return from interrupt) instruction to ensure correct operation.

*Note: The CPU priority level and the selected register bank in PSW register are not modified by the TRAP instruction; so, the service routine is executed with the same priority level as the interrupt task. Therefore, the service routine entered by the TRAP instruction can be interrupted by other traps or by higher priority interrupts, unless triggered by a real hardware event. The service routine also works with an unchanged register bank. If the hardware triggers the same service routine, register bank can be selected by the ITC and may be different.*

*Note: Software traps are also generated and issued, when data reads from the internal program memory space are requested which are not allowed, e.g. a user-read access to the protected Flash.*

## 7.9.2 Hardware Traps

Hardware Traps are issued by faults or specific system states that occur during runtime (not identified at assembly time). The XC27x5X distinguishes twelve different hardware trap functions. When a hardware trap condition has been detected, the CPU branches to the trap vector location for the respective trap condition. The instruction causing the trap event is completed before the trap handling routine is entered.

Hardware traps are not-maskable and always have a priority higher than any other CPU task. If several hardware trap conditions are detected within the same instruction cycle, the highest priority trap is serviced (see [Table 7-3](#)). In case of a hardware trap, the injection unit injects a ITRAP instruction into the pipeline. The ITRAP instruction performs the following actions:

- Push PSW, CSP (in segmented mode) and IP into the System Stack
- Set CPU level in the PSW register to the highest possible priority level, which disables all interrupts and PEC transfers
- Select the global register bank for the trap service routine
- Branch to the trap vector location specified by the trap number of the trap condition

The hardware trap functions of the core are divided in two classes.

**Class A traps** are:

- System Request 0 (SR0)
- Stack Overflow
- Stack Underflow
- Software Break

These traps share the same trap priority, but have an individual vector address.

**Class B traps** are:

- System Request 1 (SR1)
- Memory Protection
- Undefined Opcode
- Memory Access Error
- Protection Fault
- Illegal Word Operand Access

The Class B traps share the same interrupt node and interrupt vector. The bit addressable Trap Flag Register (TFR) allows a trap service routine to identify the trap which caused the exception.

*Note: The trap service routine must clear the respective trap flag; otherwise, a new trap will be requested after exiting the service routine. Setting a trap request flag by software causes the same effects as if it had been set by hardware.*

The reset functions (hardware, software, watchdog) may be also regarded as a type of trap. Reset functions have the highest priority (trap priority III). Class A traps have the

## Interrupt and Exception Control

second highest priority (trap priority II), on the 3rd rank are class B traps (trap priority I); thus, a class A trap can interrupt a class B trap (for priority see also [Table 7-3](#)).

### Class A Traps

Class A traps are generated by the high priority system request SR0 or by special CPU events such as the software break, a stack overflow, or an underflow event. Class A traps are not used to indicate hardware failures. After a class A event, a dedicated service routine is called to react to the events. Each class A trap has its own vector location in the vector table. After finishing the service routine, the instruction flow must be further correctly executed. This explains why class A traps cannot interrupt atomic/extend sequences and IO accesses in progress. For example, an interrupted extend sequence cannot be restarted.

All class A traps are generated in the pipeline during the execution of instructions, with the exception of SR0, which is an asynchronous external event. It is not possible for two different instructions in the pipeline to generate traps in the same CPU cycle. Class A trap events can be generated only during the memory stage of execution. An execution of instruction which caused a class A trap event is always completed. In the case of a class A trap, the pipeline is directly canceled and the IP of the instruction following the last executed one is pushed into the stack. In the case of an atomic/extend sequence or IO read access in progress, the execution continues till the sequence completion. Upon completion of the sequence, the IP of the instruction following the last one executed is pushed into the stack. Therefore, in the case of a class A trap, the stack always contains the IP of the first not-executed instruction in the instruction flow.

*Note: The Branch Folding Unit allows an execution of branch instructions in parallel with the preceding instruction. The pre-processed branch instruction is combined with the preceding instruction. The branch is executed together with the instruction which caused the Class A trap. The IP of the first following not-executed instruction in the instruction flow is then pushed into the stack.*

If more than one Class A trap occurs at a same time, they are prioritized internally. The SR0 trap has the highest priority and the software break has the lowest.

*Note: In the case of two different class A trap occurring simultaneously, both trap flags are set. The IP of the instruction following the last one executed is pushed into the stack. The trap with the higher priority is executed. After return from the service routine, the IP is popped from the stack and immediately pushed again because of the other pending class A trap (unless the trap related to the second trap flag in TFR has been cleared by the first trap service routine).*

### Class B Traps

Class B traps are generated by unrecoverable hardware failures. In the case of a hardware failure, the CPU must immediately start a failure service routine. Class B traps

## Interrupt and Exception Control

can interrupt an atomic/extend sequence and an IO read access. After finishing the class B service routine, a restoration of the interrupted instruction flow is not possible.

All Class B traps have the same priority (trap priority I). When several class B traps become active at the same time, the corresponding flags in the TFR register are set and the trap service routine is entered. Because all class B traps have the same vector, the priority of service of simultaneously occurring class B traps is determined by the software in the trap service routine.

All class B traps are synchronous to instruction execution; most of them are generated in the pipeline during the execution of instructions. It is not possible for two different instructions in the pipeline to generate class A and class B traps in the same CPU cycle. Class B trap events can be generated only during memory stage execution. SR1 and ACER are exceptions, because they are generated by the SCU.

Instructions which caused a class B trap event are always executed. In the case of a class B trap, the pipeline is directly canceled and the IP of the instruction following the one which caused the trap is pushed on the stack. Therefore, the stack always contains the IP of the first following not executed instruction in the instruction flow.

*Note: The Branch Folding Unit allows the execution of branch instructions in parallel with the preceding instruction. The pre-processed branch instruction is combined with the preceding instruction. The branch is executed together with the instruction causing the Class B trap. The IP of the first following not executed instruction in the instruction flow is pushed into the stack.*

During execution of a class A trap service routine, any class B trap will not be serviced until the class A trap service routine is exited with a RETI instruction. In this case, the class B trap condition is stored in the TFR register, but the IP value of the instruction which caused this trap will be lost.

*Note: If a class A trap occurs simultaneously with a class B trap, both trap flags are set. The IP of the instruction following the one which caused the trap is pushed into the stack, and the class A trap is executed. If this occurs during execution of an atomic/extend sequence or IO read access in progress, then the presence of the class B trap breaks the protection of atomic/extend operations and the class A trap will be executed immediately without waiting for the sequence completion. After return from the service routine, the IP is popped from the system stack and immediately pushed again because of the other pending class B trap. In this situation, the restoration of the interrupted instruction flow is not possible.*

- **System Request 0 Trap (A):** The control signal is generated by the SCU. See chapter SCU Trap Generation.
- **Stack Overflow Trap (A):** Whenever the stack pointer is implicitly decremented and if the stack pointer was equal to the value in the stack overflow register STKOV, the STKOF flag in register TFR is set and the CPU will enter the stack overflow trap routine.

## Interrupt and Exception Control

- **Stack Underflow Trap (A):** Whenever the stack pointer is implicitly incremented and if the stack pointer was equal to the value in the stack underflow register STKUN, the STKUF flag is set in register TFR, and the CPU will enter the stack underflow trap routine.
- **Software Break Trap (A):** When the instruction currently being executed by the CPU is a SBRK instruction, the SOFTBRK flag is set in register TFR and the CPU enters the software break debug routine. The flag generation of the software break instruction can be disabled by an On-chip Emulation Module. In this case, the instruction only breaks the instruction flow and signals this event to the debugger. The flag is not set and the trap will not be executed.
- **System Request 1 Trap (B):** The control signal is generated by the SCU. See chapter SCU Trap Generation.
- **Memory Protection Traps (B):** When an access violation outside the permitted address ranges is detected. Depending on the access type it is differentiated between Read (MPR), Write (MPW) and Execute (MPX) violations.
- **Undefined Opcode Trap (B):** When the instruction currently being decoded by the CPU does not contain a valid C166SV2 opcode, the UNDOPC flag is set in register TFR and the CPU enters the undefined opcode trap routine. The instruction which causes the undefined opcode trap is executed as a NOP.
- **Memory Access Error (B):** The control signal is generated by the SCU. See chapter SCU Trap Generation.
- **Protection Fault Trap (B):** Whenever one of the special protected instructions is executed where the opcode of that instruction is not repeated twice in the second word of the instruction and the byte following the opcode is not the complement of the opcode, the PRTFLT flag in register TFR is set and the CPU enters the protection fault trap routine. The protected instructions include DISWDT, EINIT, IDLE, PWRDN, SRST, ENWDT and SRVWDT. The instruction which causes the protection fault trap is executed as a NOP. For products supporting MPU, RETI is also defined as a protected instruction in the sense that its execution is only allowed for privileged code, i.e. code executed with protection level 0. This flag is then used to indicate that a RETI instruction was tried to be executed from a protection level different to 0. Note that RETI will be still executed even if it causes a protection fault trap (it is not executed as a NOP).
- **Illegal Word Operand Access Trap (B):** Whenever a word operand read or write access (including Flash commands!) is attempted to an odd byte address, the ILLOPA flag in register TFR is set and the CPU enters the illegal word operand access trap routine.

## Trap Vector Locations

**Table 7-3** lists the vector locations for hardware traps and the corresponding status flags in register TFR. It also lists the priorities of trap service for those cases in which more than one trap condition might be detected within the same instruction. After any reset

## Interrupt and Exception Control

(hardware reset, software reset instruction SRST, or reset by watchdog timer overflow) program execution starts at the reset vector at location  $xx'0000_H$ . Reset conditions have priority over every other system activity and, therefore, have the highest priority (trap priority III).

Software traps may be initiated to any defined vector location. A service routine entered via a software TRAP instruction is always executed on the current CPU priority level which is indicated in bitfield ILVL in register PSW. This means that routines entered via the software TRAP instruction can be interrupted by all hardware traps or higher level interrupt requests.

**Table 7-3    Hardware Trap Summary**

| Exception Condition           | Trap Flag | Trap Vector | Vector Location <sup>1)</sup> | Vector Number | Trap Priority |
|-------------------------------|-----------|-------------|-------------------------------|---------------|---------------|
| Application Reset             | –         | RESET       | $xx'0000_H$                   | $00_H$        | III           |
| Class A Hardware Traps:       |           |             |                               |               |               |
| • System Request 0            | SR0       | SR0TRAP     | $xx'0008_H$                   | $02_H$        | II            |
| • Stack Overflow              | STKOF     | STOTRAP     | $xx'0010_H$                   | $04_H$        | II            |
| • Stack Underflow             | STKUF     | STUTRAP     | $xx'0018_H$                   | $06_H$        | II            |
| • Software Break              | SOFTBRK   | SBRKTRAP    | $xx'0020_H$                   | $08_H$        | II            |
| Class B Hardware Traps:       |           |             |                               |               |               |
| • System Request 1            | SR1       | BTRAP       | $xx'0028_H$                   | $0A_H$        | I             |
| • Memory Protection           | MPR/W/X   | BTRAP       | $xx'0028_H$                   | $0A_H$        | I             |
| • Undefined Opcode            | UNDOPC    | BTRAP       | $xx'0028_H$                   | $0A_H$        | I             |
| • Memory Access Error         | ACER      | BTRAP       | $xx'0028_H$                   | $0A_H$        | I             |
| • Protected Instruction Fault | PRTFLT    | BTRAP       | $xx'0028_H$                   | $0A_H$        | I             |
| • Illegal Word Operand Access | ILLOPA    | BTRAP       | $xx'0028_H$                   | $0A_H$        | I             |

<sup>1)</sup> Register VECSEG defines the segment where the vector table is located to.

Bitfield VECSC in register CPUCON1 defines the distance between two adjacent vectors. This table represents the default setting, with a distance of 4 (two words) between two vectors.

## Interrupt and Exception Control

### 7.9.2.1 The Trap Flag Register TFR

The XC27x5X provides a number of trap vectors (class A and class B) which are indicated in the trap flag register TFR.

**TFR**
**Trap Flag Register**
**SFR(FFAC<sub>H</sub>/D6<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**

| 15         | 14            | 13            | 12               | 11         | 10         | 9          | 8          | 7              | 6        | 5        | 4            | 3              | 2              | 1        | 0        |
|------------|---------------|---------------|------------------|------------|------------|------------|------------|----------------|----------|----------|--------------|----------------|----------------|----------|----------|
| <b>SR0</b> | <b>STK OF</b> | <b>STK UF</b> | <b>SOF T BRK</b> | <b>SR1</b> | <b>MPR</b> | <b>MPW</b> | <b>MPX</b> | <b>UND OPC</b> | <b>0</b> | <b>0</b> | <b>AC ER</b> | <b>PRT FLT</b> | <b>ILL OPA</b> | <b>0</b> | <b>0</b> |
| rwh        | rwh           | rwh           | rwh              | rwh        | rwh        | rwh        | rwh        | rwh            | r        | r        | rwh          | rwh            | rwh            | r        | r        |

| Field          | Bits | Type | Description                                                                                                                                                                |
|----------------|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>SR0</b>     | 15   | rwh  | <b>System request flag 0</b><br>0 <sub>B</sub> No trigger detected<br>1 <sub>B</sub> The selected condition has been detected                                              |
| <b>STKOF</b>   | 14   | rwh  | <b>Stack overflow flag</b><br>0 <sub>B</sub> No stack overflow event detected<br>1 <sub>B</sub> The current stack pointer value falls below the contents of register STKOV |
| <b>STKUF</b>   | 13   | rwh  | <b>Stack underflow flag</b><br>0 <sub>B</sub> No stack underflow event detected<br>1 <sub>B</sub> The current stack pointer value exceeds the contents of register STKUN   |
| <b>SOFTBRK</b> | 12   | rwh  | <b>Software Break</b><br>0 <sub>B</sub> No software break event detected<br>1 <sub>B</sub> Software break event detected                                                   |
| <b>SR1</b>     | 11   | rwh  | <b>System request flag 1</b><br>0 <sub>B</sub> No trigger detected<br>1 <sub>B</sub> The selected condition has been detected                                              |
| <b>MPR</b>     | 10   | rwh  | <b>Memory Protection Read</b><br>0 <sub>B</sub> No read protection violation detected<br>1 <sub>B</sub> Read protection violation detected                                 |
| <b>MPW</b>     | 9    | rwh  | <b>Memory Protection Write</b><br>0 <sub>B</sub> No write protection violation detected<br>1 <sub>B</sub> Write protection violation detected                              |

## Interrupt and Exception Control

| Field         | Bits            | Type | Description                                                                                                                                                                   |
|---------------|-----------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>MPX</b>    | 8               | rwh  | <b>Memory Protection Execute</b><br>$0_B$ No execute protection violation detected<br>$1_B$ Execute protection violation detected                                             |
| <b>UNDOPC</b> | 7               | rwh  | <b>Undefined Opcode</b><br>$0_B$ No undefined opcode event detected<br>$1_B$ The currently decoded instruction has no valid opcode                                            |
| <b>ACER</b>   | 4               | rwh  | <b>Memory Access Error</b><br>$0_B$ No access error event detected<br>$1_B$ Illegal or erroneous access detected                                                              |
| <b>PRTFLT</b> | 3               | rwh  | <b>Protection Fault</b><br>$0_B$ No protection fault event detected<br>$1_B$ A protected instruction with an illegal format has been detected                                 |
| <b>ILLOPA</b> | 2               | rwh  | <b>Illegal word operand access</b><br>$0_B$ No illegal word operand access event detected<br>$1_B$ A word operand access (read or write) to an odd address has been attempted |
| <b>0</b>      | [6:5],<br>[1:0] | r    | <b>Reserved</b><br>read as 0; should be written with 0.                                                                                                                       |

Note: Flags TFR.15, TFR.11 and TFR.4 are generated via SCU. TFR.8, TFR9 and TFR.10 are generated via MPU. Other flags are generated by the CPU.

## Interrupt and Exception Control

### 7.10 Peripheral Event Controller

The XC27x5X's Peripheral Event Controller (PEC) provides 8 PEC service channels which move a single byte or word between any two locations. A PEC transfer can be triggered by an interrupt service request and is the fastest possible interrupt response. In many cases a PEC transfer is sufficient to service the respective peripheral request (for example, serial channels, etc.).

PEC transfers do not change the current context, but rather "steal" cycles from the CPU, so the current program status and context needs not to be saved and restored as with standard interrupts.

The PEC channels can perform the following actions:

- Byte or word transfer
- Continuous data transfer
- PEC channel-specific interrupt request upon data transfer completion or common for all channels "End of PEC" interrupt for enhanced handling
- Automatic increment of source or/and destination pointers with support of memory to memory transfer

*Note: PEC transfer is executed if its priority level is higher than current CPU priority level.*

## Interrupt and Exception Control

### 7.10.1 PEC Control Registers

Each PEC channel is controlled by the respective **PEC** channel Control register (PECC $x$ ) and a set of source and destination pointers (SRCP $x$ , DSTP $x$  and PECSEG $x$ ), where  $x$  stands for the PEC channel number. The PECC $x$  registers control the arbitration priority level assignment to the PEC channels and the action to be performed.

#### PECC $x$ ( $x=0-7$ )

**PEC Channel Control  $x$**       **SFR(FEC0 $H$ +2\* $x$ )**      **Reset Value: 0000 $H$**

| 15 | 14      | 13   | 12 | 11  | 10  | 9 | 8 | 7 | 6 | 5 | 4 | 3     | 2 | 1 | 0 |
|----|---------|------|----|-----|-----|---|---|---|---|---|---|-------|---|---|---|
| 0  | EOP INT | PLEV | CL | INC | BWT |   |   |   |   |   |   | COUNT |   |   |   |

Bit descriptions: r=r, rw=rw, rwh=rwh

| Field  | Bits    | Type | Description                                                                                                                                                                                                                                                                                                  |
|--------|---------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EOPINT | 14      | rw   | <b>End of PEC Interrupt Selection</b><br>0 <sub>B</sub> End of PEC interrupt with the same level as the PEC transfer is triggered<br>1 <sub>B</sub> End of PEC interrupt is serviced by a separate interrupt node with programmable interrupt level (EOPIC) and interrupt sharing control register (PECISNC) |
| PLEV   | [13:12] | rw   | <b>Programmable PEC Interrupt Level</b><br>00 <sub>B</sub> Standard (compatible mode): Levels 15 and 14<br>01 <sub>B</sub> Levels 13 and 12<br>10 <sub>B</sub> Levels 11 and 10<br>11 <sub>B</sub> Levels 9 and 8                                                                                            |
| CL     | 11      | rw   | <b>Channel Link Control</b><br>0 <sub>B</sub> PEC channels work independent<br>1 <sub>B</sub> Pairs of channels are linked together                                                                                                                                                                          |

## Interrupt and Exception Control

| Field        | Bits   | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------|--------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>INC</b>   | [10:9] | rw   | <b>Increment Control</b><br>(Modification of source and destination pointer after PEC transfer)<br>00 <sub>B</sub> No modification<br>01 <sub>B</sub> Increment of destination pointer DSTPx by 1 (BWT = 1) or by 2 (BWT = 0)<br>10 <sub>B</sub> Increment of source pointer SRCPx by 1 (BWT = 1) or by 2 (BWT = 0)<br>11 <sub>B</sub> Increment of destination pointer DSTPx and source pointer SRCPx by 1 (BWT = 1) or by 2 (BWT = 0) |
| <b>BWT</b>   | 8      | rw   | <b>Byte/Word Transfer Selection</b><br>0 <sub>B</sub> Transfer a word<br>1 <sub>B</sub> Transfer a byte                                                                                                                                                                                                                                                                                                                                 |
| <b>COUNT</b> | [7:0]  | rwh  | <b>PEC Transfer Count</b><br>Counts PEC transfers and influences the channel's action (see <a href="#">Table 7-4</a> )                                                                                                                                                                                                                                                                                                                  |
| <b>0</b>     | 15     | r    | <b>Reserved</b><br>read as 0; should be written with 0.                                                                                                                                                                                                                                                                                                                                                                                 |

The **Byte/Word Transfer Bit** (BWT) of the PECCx register selects if a byte or a word is to be moved during a PEC service cycle and defines an increment step size for the pointer(s) to be modified.

The **PEC Transfer Count Field** (COUNT) of the PECCx directly controls the action of the respective PEC channel. The contents of the bitfield COUNT may specify a certain number of PEC transfers, unlimited transfers, or no PEC service at all.

- If the PEC transfer counter COUNT value is set to **00<sub>H</sub>**, the normal interrupt requests are processed instead of PEC data transfers and the corresponding PEC channel remains idle.
- **Continuous data transfers** are selected by setting the bitfield COUNT to **FF<sub>H</sub>** value. In this case, COUNT is not decremented by the transfers and the respective PEC channel can serve unlimited number of PEC requests until it is modified by the program.
- If the bitfield COUNT is set to service a specified number of requests by the respective PEC channel, it is decremented with each PEC transfer and the request flag is cleared to indicate that the request has been serviced. When COUNT reaches **00<sub>H</sub>**, it activates the interrupt service routine which has the same priority level

## Interrupt and Exception Control

(EOPINT = 0) or triggers the “End of PEC” interrupt with a different priority level (EOPINT = 1). When COUNT is **decremented from 01<sub>H</sub> to 00<sub>H</sub>** after a data transfer, the request flag will be cleared if EOPINT is set to 1. If EOPINT is 0, the request flag will not be cleared and another interrupt request will be generated on the same priority level. The respective PEC channel remains idle and the associated interrupt service routine is activated instead of PEC transfer because COUNT contains the 00<sub>H</sub> value. (see [Section 7.10.3](#)).

The EOPICT register is the interrupt control register of the End Of PEC interrupt.

### EOPIC

**End Of PEC Interrupt Control    ESFR(F19E<sub>H</sub>/CF<sub>H</sub>)    Reset Value: 0000<sub>H</sub>**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7      | 6      | 5 | 4    | 3 | 2    | 1 | 0 |
|----|----|----|----|----|----|---|-----|--------|--------|---|------|---|------|---|---|
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | GPX | EOP IR | EOP IE |   | ILVL |   | GLVL |   |   |

r      r      r      r      r      r      r      rw      rwh      rw           rw           rw           rw

| Field | Bits   | Type | Description                                                                                                                        |
|-------|--------|------|------------------------------------------------------------------------------------------------------------------------------------|
| GPX   | 8      | rw   | <b>Group Priority Extension</b><br>Defines the value of high-order group level bit                                                 |
| EOPIR | 7      | rwh  | <b>Interrupt Request Flag</b><br>0 <sub>B</sub> No request pending<br>1 <sub>B</sub> The source has raised an interrupt request    |
| EOPIE | 6      | rw   | <b>Interrupt Enable Control Bit</b><br>0 <sub>B</sub> Interrupt request is disabled<br>1 <sub>B</sub> Interrupt request is enabled |
| ILVL  | [5:2]  | rw   | <b>Interrupt Priority Level</b><br>F <sub>H</sub> Highest priority level<br>...<br>0 <sub>H</sub> Lowest priority level            |
| GLVL  | [1:0]  | rw   | <b>Group Priority Level</b><br>3 <sub>H</sub> Highest priority level<br>...<br>0 <sub>H</sub> Lowest priority level                |
| 0     | [15:9] | r    | <b>Reserved</b><br>read as 0; should be written with 0.                                                                            |

## Interrupt and Exception Control

*Note: The concatenation of the group priority extension bit GPX and the group priority level bitfield GLVL builds the 3-bit Extended Group Priority Level XGLVL, where  $7_H$  is the highest priority level and  $0_H$  is the lowest priority level.*

The Register **PECISNC** contains flags of the “End of PEC” interrupt node. This node is used when enhanced “End of PEC” interrupt feature was invoked and control bit EOPINT is set to 1 in the corresponding **PECCx**.

### PECISNC

#### PEC Interrupt Sub Node Control SFR(FFD8<sub>H</sub>/EC<sub>H</sub>)

**Reset Value: 0000<sub>H</sub>**

| 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|
| C7IR | C7IE | C6IR | C6IE | C5IR | C5IE | C4IR | C4IE | C3IR | C3IE | C2IR | C2IE | C1IR | C1IE | C0IR | C0IE |
| rwh  | rw   |

| Field           | Bits  | Type | Description                                                                                                                                                                                                                                                                             |
|-----------------|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CxIR<br>(x=0-7) | 2*x+1 | rwh  | <b>Interrupt Sub Node Request Flag of PEC Channel x</b> <sup>1)</sup><br>0 <sub>B</sub> No special end of PEC interrupt request is pending for PEC channel x<br>1 <sub>B</sub> PEC channel x has raised an end of PEC interrupt request                                                 |
| CxIE<br>(x=0-7) | 2*x   | rw   | <b>Interrupt Sub Node Enable Control Bit of PEC Channel x</b> <sup>2)</sup><br>(individually enables/disables a specific source)<br>0 <sub>B</sub> End of PEC interrupt request of PEC channel x is disabled<br>1 <sub>B</sub> End of PEC interrupt request of PEC channel x is enabled |

<sup>1)</sup> x = 7...0, depending on PEC channel number

<sup>2)</sup> It is recommended to clear an interrupt request flag (CxIR) before setting the respective enable flag (CxIE). Otherwise, former requests still pending will immediately trigger an interrupt request after setting the enable bit.

*Note: The “End of PEC” sub-node interrupt request flags are not cleared by hardware when entering the interrupt service routine (interrupt has been accepted by the CPU), unlike the interrupt request flags of the interrupt nodes (request flags xxIC.xxIR). The interrupt service routine must check the request flags and clear them before executing the RETI instruction.*

The following figure shows the usage of the “End of PEC” interrupt subnode:

**Interrupt and Exception Control**

**Figure 7-3 End of PEC Interrupt Sub Node**

The table below summarizes the values of the bitfield COUNT and the corresponding PEC channel actions

**Table 7-4 PEC Channel Actions**

| Previous COUNT field value         | Modified COUNT field value         | Action of PEC Channel and Comments                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------------------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FF <sub>H</sub>                    | FF <sub>H</sub>                    | <b>Move a Byte/Word</b><br>Continuous transfer mode, i.e. COUNT is not modified                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| FE <sub>H</sub> ...02 <sub>H</sub> | FD <sub>H</sub> ...01 <sub>H</sub> | Move a Byte/Word and decrement COUNT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 01 <sub>H</sub>                    | 00 <sub>H</sub>                    | <b>Move a Byte/Word</b><br>Depending on bit EOPINT, one of two different actions are taken:<br><b>EOPINT = 0</b> (compatible mode)<br>The service request flag (xxIR) of the respective interrupt remains set (it is cleared for all other COUNT values). Therefore, an additional interrupt request is triggered on the next arbitration cycle with a COUNT field value of 00 <sub>H</sub> (see next raw)<br><b>EOPINT = 1</b><br>The service request flag (xxIR) of the respective interrupt is cleared. Additionally, the interrupt request flag of the EOP sub node (PECISNC.CxIR) is set. Furthermore, the interrupt request flag of the end of PEC interrupt node (EOPIC.EOPIR) is automatically set if the sub node request is enabled (PECISNC.CxIE = '1').<br>(see also <a href="#">Section 7.10.3</a> ) |
| 00 <sub>H</sub>                    | 00 <sub>H</sub>                    | <b>No PEC action!</b><br>A normal interrupt is requested instead of a PEC data transfer (see also <a href="#">Section 7.10.3</a> ).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

The **Increment Control Field (INC)** of the PECCx register defines whether one or both of the PEC pointers must be incremented after the PEC transfer. If the pointers are not to be modified (INC='00'), the respective channel will always move data from the same source to the same destination.

### Channel Link Mode for Data Chaining

Channel linking, if enabled, links two channels together to serve the data transfer requests of one peripheral. The whole data transfer (for example a message) is divided into separately controlled and chained block transfers. The two PEC channels which are linked together, handle chained block transfers alternately to each other. At the end of a

## Interrupt and Exception Control

data block transfer, controlled by one PEC channel, automatically the other (linked) PEC channel is started to continue the transfer with the next data block. Channel linking and thus data (block) chaining is supported within pairs of PEC channels (channels 0&1, 2&3 a.s.o.). Each data block is controlled by one PEC channel of the channel pair. While one of the two channels is active, the CPU can update the pointer and counter values of the other channel to prepare it for continuation of data transfer after next channel linking.

Channel linking is enabled, if in the active PEC channel of the channel pair the Channel Link Control Bit “CL” in its PECCx register is set to 1. The data transfer of linked channels is started always with the even numbered channel of the channel pair. If in Channel Link mode (at least one CL bit of the pair is set) the channel’s data block is completely transferred the PEC service request processing is automatically switched to the other PEC channel of the channel-pair.

Channel linking and thus the switching from one channel to the other channel is performed, when the CL bit of first (active) channel is set (in its PEC control register) and its transfer count is changed from one to zero with last transfer. If the channel link flag CL of the first (terminated) PEC control register is found to be zero or the count field of linked channel is zero, the whole data transfer is finished.

*Note: The CL-flags are fully controlled by software and should be cleared by SW when the whole data transfer shall be finished and the termination of transfer shall be executed. Because termination can also be entered with a zero-value of the transfer count field of linked channel, termination of whole data transfer is automatically performed if the channels count field was not updated after the last channel link interrupt for this channel.*

When a data block of a linked channel is completely transferred and PEC servicing switches to the other channel of channel pair, a channel specific channel link interrupt is generated (for old channel) to inform the CPU that the channel is inactive now and may be configured for its next block transfer. The channel link interrupt is requested, indicated and enabled in the respective PEC Interrupt Subnode Control Register (PECISNC), which is also used for the channel’s End of PEC interrupt (see chapter above). Thus, all channel link interrupts are also controlled with the one EOP interrupt control register EOPIC and therefore with the same interrupt priority level as the EOP interrupt. This service request node requests CPU interrupt service in case of one or more pending channel link interrupt requests or End of PEC interrupt requests, if the respective enable control bit(s) is (are) set in the PEC interrupt subnode control register PECISNC and in the interrupt control register EOPIC.

*Note: The generation of Channel Link/EOP interrupt is automatically enabled, if the CL-bit of the active (terminated) channel is set. If it is not set, either a standard interrupt or an EOP interrupt is initiated according to the EOPINT bit in the channel’s PEC Control Register. The channel is not switched in this case, because a missing CL flag defines the last block of data transfer.*

## Interrupt and Exception Control

*Note: If Channel Link mode is active (at least one of the pair's CL bits is set), interrupt requests connected to the odd channel (via priority levels) will trigger only a standard interrupt but no PEC transfer.*

*Note: The start of data transfer on linked channels is always performed with the even numbered PEC channel of the channel pair.*

## Interrupt and Exception Control

### 7.10.2 The PEC Source and Destination Pointer

The PEC channels source and destination pointers specify the locations between which the data is to be moved. All pointers are 24-bits wide. The 24-bit source address is stored in the register SRCPx (lower 16 bits of address) and in the high byte of register PECSEGx (highest 8 address bits).



**Figure 7-4 PEC Pointer Address Handling**

The 24-bit destination address is stored in the register DSTPx (lower 16 bits of address) and in the low byte of register PECSEGx (highest 8 address bits). Only the lower 16 bits of the PEC address pointers (segment offset) can be modified (incremented) by the PEC transfer mechanism. The highest 8 bits, which represent the segment number, are not modified by hardware. Therefore, the PEC pointers may be incremented within the address space of one segment and may not cross the segment border. If the offset address pointer gets the  $\text{FFFF}_H$  value in case of byte transfers ( $\text{BWT} = 1$ ) or  $\text{FFFE}_H$  in case of word transfers ( $\text{BWT} = 0$ ), the next increment will be disregarded. The address register will keep one of these maximum values and no overflow will happen. The described behavior protects the subsequent memory from unintentional overwriting. No

## Interrupt and Exception Control

explicit error event is generated by the system in case of address pointer(s) saturation; therefore, it is the user's responsibility to prevent this condition.

*Note: PEC data transfers do not use the data page pointers DPP3...DPP0.*

*Note: If a word data transfer is selected for a specific PEC channel (i.e. BWT = 0), the respective source and destination pointers must both contain a valid word address which points to an even byte boundary. Otherwise, the Illegal Word Operand Access trap will be invoked when this channel is used.*

### SRCPx (x=0-7)

PEC Source Pointer x

XSFR(EC40<sub>H</sub>+4\*x)

Reset Value: 0000<sub>H</sub>



| Field | Bits   | Type | Description                                                               |
|-------|--------|------|---------------------------------------------------------------------------|
| SRCPx | [15:0] | rwh  | <b>Source Pointer Offset of Channel x</b><br>Source address bits 15 ... 0 |

x = 7...0, depending on PEC channel number

### DSTPx (x=0-7)

PEC Destination Pointer x

XSFR(EC42<sub>H</sub>+4\*x)

Reset Value: 0000<sub>H</sub>



| Field | Bits   | Type | Description                                                                         |
|-------|--------|------|-------------------------------------------------------------------------------------|
| DSTPx | [15:0] | rwh  | <b>Destination Pointer Offset of Channel x</b><br>Destination address bits 15 ... 0 |

x = 7...0, depending on PEC channel number

For XSFR addresses see [Table 7-11](#).

## Interrupt and Exception Control

**PECSEG<sub>x</sub> (x=0-7)**
**PEC Segment Pointer x**
**XCSR(EC80<sub>H</sub>+2\*x)**
**Reset Value: 0000<sub>H</sub>**


| Field                     | Bits   | Type | Description                                                                                   |
|---------------------------|--------|------|-----------------------------------------------------------------------------------------------|
| <b>SRCSEG<sub>x</sub></b> | [15:8] | rw   | <b>Source Pointer Segment of Channel x</b><br>Source address bits 23 ... 16                   |
| <b>DSTSEG<sub>x</sub></b> | [7:0]  | rw   | <b>Destination Pointer Segment Address of Channel x</b><br>Destination address bits 23 ... 16 |

x = 7...0, depending on PEC channel number

### 7.10.3 PEC Interrupt Processing Summary

As described above, two different kinds of interrupts can be triggered by the PEC handler depending on the status of the bitfield COUNT.

- PEC channel is enabled<sup>1)</sup> and the bitfield COUNT has a value higher then 01<sub>H</sub>.
  - Control bit EOPINT = 0 or 1
 

**ACTIONS:**

    - PEC request is proceeded
    - No other interrupt activity
- PEC channel is enabled and the bitfield COUNT gets a decrement from 01<sub>H</sub> to 00<sub>H</sub> triggered by a service request.
  - Control bit EOPINT = 0 (compatible with C166)
 

**ACTIONS:**

    - PEC request is proceeded
    - Interrupt request flag (xxIR) of the requesting interrupt node (arbitration winner) is not cleared, participates on the next arbitration cycle, and triggers a normal interrupt on the same level as the PEC request is served.
  - Control bit EOPINT = 1 (enhanced end of PEC interrupt feature)
 

**ACTIONS:**

    - PEC request is proceeded

<sup>1)</sup> Every PEC channel is automatically enabled, when its COUNT value is greater than 00<sub>H</sub>.

## Interrupt and Exception Control

- Interrupt request flag (xxIR) of requesting interrupt node (arbitration winner) is cleared and will not trigger more actions.
  - Interrupt request flag of the end of PEC interrupt subnode will be set (PECISNC.CxIR = 1)
  - If the respective interrupt enable flag of the end of PEC interrupt subnode was set before by software (PECISNC.CxE = 1), an end of PEC interrupt is requested (EOPIC.EOPIR = 1). This end of PEC interrupt participates on the next arbitration cycle with its priority (selected via EOPIC.ILVL and EOPIC.GLVL), if this interrupt source was enabled before by software (EOPIC.EOPIR = 1). With this behavior an end of PEC interrupt can be triggered on a lower level than the respective PEC requests have been serviced.
- PEC channel is disabled if the bitfield COUNT is cleared (either by hardware or by software)
- Control bit EOPINT = 0 or 1
- ACTIONS:**
- A normal interrupt service routine is requested on the PEC channel priority level.

### 7.10.4 PEC Channel Assignment

The PEC channel used for executing the transfer depends on the programming of the interrupt, group and PEC level. The following table lists the channel assignments.

**Table 7-5 PEC Channel Assignment**

| ICx.<br>ILVL      | ICx.<br>GLVL    | PECCy.<br>PLEV  | Assigned<br>PEC Channel | ICx.<br>ILVL      | ICx.<br>GLVL    | PECCy.<br>PLEV  | Assigned<br>PEC Channel |
|-------------------|-----------------|-----------------|-------------------------|-------------------|-----------------|-----------------|-------------------------|
| 1111 <sub>B</sub> | 11 <sub>B</sub> | 00 <sub>B</sub> | 7                       | 1011 <sub>B</sub> | 11 <sub>B</sub> | 10 <sub>B</sub> | 7                       |
| 1111 <sub>B</sub> | 10 <sub>B</sub> |                 | 6                       | 1011 <sub>B</sub> | 10 <sub>B</sub> |                 | 6                       |
| 1111 <sub>B</sub> | 01 <sub>B</sub> |                 | 5                       | 1011 <sub>B</sub> | 01 <sub>B</sub> |                 | 5                       |
| 1111 <sub>B</sub> | 00 <sub>B</sub> |                 | 4                       | 1011 <sub>B</sub> | 00 <sub>B</sub> |                 | 4                       |
| 1110 <sub>B</sub> | 11 <sub>B</sub> |                 | 3                       | 1010 <sub>B</sub> | 11 <sub>B</sub> |                 | 3                       |
| 1110 <sub>B</sub> | 10 <sub>B</sub> |                 | 2                       | 1010 <sub>B</sub> | 10 <sub>B</sub> |                 | 2                       |
| 1110 <sub>B</sub> | 01 <sub>B</sub> |                 | 1                       | 1010 <sub>B</sub> | 01 <sub>B</sub> |                 | 1                       |
| 1110 <sub>B</sub> | 00 <sub>B</sub> |                 | 0                       | 1010 <sub>B</sub> | 00 <sub>B</sub> |                 | 0                       |

## Interrupt and Exception Control

**Table 7-5 PEC Channel Assignment**

| ICx.<br>ILVL      | ICx.<br>GLVL    | PECCy.<br>PLEV  | Assigned<br>PEC Channel | ICx.<br>ILVL      | ICx.<br>GLVL    | PECCy.<br>PLEV  | Assigned<br>PEC Channel |
|-------------------|-----------------|-----------------|-------------------------|-------------------|-----------------|-----------------|-------------------------|
| 1101 <sub>B</sub> | 11 <sub>B</sub> | 01 <sub>B</sub> | 7                       | 1001 <sub>B</sub> | 11 <sub>B</sub> | 11 <sub>B</sub> | 7                       |
| 1101 <sub>B</sub> | 10 <sub>B</sub> |                 | 6                       | 1001 <sub>B</sub> | 10 <sub>B</sub> |                 | 6                       |
| 1101 <sub>B</sub> | 01 <sub>B</sub> |                 | 5                       | 1001 <sub>B</sub> | 01 <sub>B</sub> |                 | 5                       |
| 1101 <sub>B</sub> | 00 <sub>B</sub> |                 | 4                       | 1001 <sub>B</sub> | 00 <sub>B</sub> |                 | 4                       |
| 1100 <sub>B</sub> | 11 <sub>B</sub> |                 | 3                       | 1000 <sub>B</sub> | 11 <sub>B</sub> |                 | 3                       |
| 1100 <sub>B</sub> | 10 <sub>B</sub> |                 | 2                       | 1000 <sub>B</sub> | 10 <sub>B</sub> |                 | 2                       |
| 1100 <sub>B</sub> | 01 <sub>B</sub> |                 | 1                       | 1000 <sub>B</sub> | 01 <sub>B</sub> |                 | 1                       |
| 1100 <sub>B</sub> | 00 <sub>B</sub> |                 | 0                       | 1000 <sub>B</sub> | 00 <sub>B</sub> |                 | 0                       |

All interrupt requests not assigned to a PEC channel go directly to the interrupt handler.

## 7.11 External Interrupts

Although the XC27x5X has no dedicated interrupt input pins, it supports many possibilities to react to external asynchronous events by providing a number of IO lines which can be selected as interrupt inputs.

### 7.11.1 External Request Unit

Please refer to the [External Request Unit \(ERU\)](#) chapter. The ERU provides routing capabilities and allows to define advanced trigger conditions for the interrupt input signals. The resulting ERU interrupt requests are forwarded to the interrupt controller registers SCU\_ERU\_0IC ... SCU\_ERU\_3IC.

### 7.11.2 Using Peripheral Pins

The interrupt function of some peripheral pins may be either combined with the pin's main function or used instead of it if the main pin function is not required.

**Table 7-6 Pins Usable as External Interrupt Inputs**

| Port Pin          | Original Function                                 | Control Register        |
|-------------------|---------------------------------------------------|-------------------------|
| P4.7-0/CC31-24IO  | CAPCOM Register 31-24 Capture Input               | CC31-CC24 <sup>1)</sup> |
| P2.10-3/CC23-16IO | CAPCOM Register 23-16 Capture Input <sup>2)</sup> | CC23-CC16 <sup>1)</sup> |
| P4.2/T2IN         | Auxiliary timer T2 input pin                      | T2CON                   |
| P4.6/T4IN         | Auxiliary timer T4 input pin                      | T4CON                   |
| P2.10/CAPIN       | GPT2 capture input pin <sup>2)</sup>              | T5CON                   |

<sup>1)</sup> Must be enabled by [Interrupt Node Sharing](#).

<sup>2)</sup> Pin P2.10 overlays two possible input functions.

For each of these pins, either a positive, a negative, or both a positive and a negative external transition can be selected to cause an interrupt or PEC service request. The edge selection is performed in the control register of the peripheral device associated with the respective port pin. The peripheral must be programmed to a specific operating mode to allow generation of an interrupt by the external signal. The priority of the interrupt request is determined by the interrupt control register of the respective peripheral interrupt source, and the interrupt vector of this source will be used to service the external interrupt request.

*Note: In order to use any of the listed pins as an external interrupt input, it must be switched to input mode via its port control register.*

When port pins CCxIO are to be used as external interrupt input pins, bitfield CCMODx in the control register of the corresponding capture/compare register CCx must select capture mode. When CCMODx is programmed to 001<sub>B</sub>, the interrupt request flag CCxIR

## Interrupt and Exception Control

in register CCxIC will be set on a positive external transition at pin CCxIO. When CCMODx is programmed to  $010_B$ , a negative external transition will set the interrupt request flag. When  $CCMODx = 011_B$ , both a positive and a negative transition will set the request flag. In all three cases, the contents of the allocated CAPCOM timer will be latched into capture register CCx, independent of whether or not the timer is running. When the interrupt enable bit CCxIE is set, a PEC request or an interrupt request for vector CCxINT will be generated.

Pins T2IN or T4IN can be used as external interrupt input pins when the associated auxiliary timer T2 or T4 in block GPT1 is configured for capture mode. This mode is selected by programming the mode control fields T2M or T4M in control registers T2CON or T4CON to  $101_B$ . The active edge of the external input signal is determined by bitfields T2I or T4I. When these fields are programmed to  $X01_B$ , interrupt request flags T2IR or T4IR in registers T2IC or T4IC will be set on a positive external transition at pins T2IN or T4IN, respectively. When T2I or T4I is programmed to  $X10_B$ , then a negative external transition will set the corresponding request flag. When T2I or T4I is programmed to  $X11_B$ , both a positive and a negative transition will set the request flag. In all three cases, the contents of the core timer T3 will be captured into the auxiliary timer registers T2 or T4 based on the transition at pins T2IN or T4IN. When the interrupt enable bits T2IE or T4IE are set, a PEC request or an interrupt request for vector T2INT or T4INT will be generated.

Pin CAPIN differs slightly from the timer input pins as it can be used as external interrupt input pin without affecting peripheral functions. When the capture mode enable bit T5SC in register T5CON is cleared to '0', signal transitions on pin CAPIN will only set the interrupt request flag CRIR in register CRIC, and the capture function of register CAPREL is not activated.

So register CAPREL can still be used as reload register for GPT2 timer T5, while pin CAPIN serves as external interrupt input. Bitfield CI in register T5CON selects the effective transition of the external interrupt input signal. When CI is programmed to  $01_B$ , a positive external transition will set the interrupt request flag.  $CI = 10_B$  selects a negative transition to set the interrupt request flag, and with  $CI = 11_B$ , both a positive and a negative transition will set the request flag. When the interrupt enable bit CRIE is set, an interrupt request for vector CRINT or a PEC request will be generated.

## Interrupt and Exception Control

### 7.12 OCDS Requests

The OCDS module issues high-priority break requests or standard service requests. The break requests are routed directly to the CPU (like the hardware trap requests) and are prioritized there. Therefore, break requests ignore the standard interrupt arbitration and receive highest priority.

The standard OCDS service requests are routed to the CPU Action Control Unit together with the arbitrated interrupt/PEC requests. The service request with the higher priority is sent to the CPU to be serviced. If both the interrupt/PEC request and the OCDS request have the same priority level, the interrupt/PEC request wins.

This approach ensures precise break control, while affecting the system behavior as little as possible.

The CPU Action Control Unit also routes back request acknowledges and denials from the core to the corresponding requestor.

## Interrupt and Exception Control

## 7.13 Service Request Latency

The numerous service requests of the XC27x5X (requests for interrupt or PEC service) are generated asynchronously with respect to the execution of the instruction flow. Therefore, these requests are arbitrated and are inserted into the current instruction stream. This decouples the service request handling from the currently executed instruction stream, but also leads to a certain latency.

The request latency is the time from activating a request signal at the interrupt controller (ITC) until the corresponding instruction reaches the pipeline's execution stage.

**Table 7-7** lists the consecutive steps required for this process.

**Table 7-7 Steps Contributing to Service Request Latency**

| Description of Step                                                                                  | Interrupt Response         | PEC Response |
|------------------------------------------------------------------------------------------------------|----------------------------|--------------|
| Request arbitration in 3 stages, leads to acceptance by the CPU (see <a href="#">Section 7.2</a> )   | 3 cycles                   | 3 cycles     |
| Injection of an internal instruction into the pipeline's instruction stream                          | 4 cycles                   | 4 cycles     |
| The first instruction fetched from the interrupt vector table reaches the pipeline's execution stage | 4 cycles / 0 <sup>1)</sup> | - - -        |
| Resulting minimum request latency                                                                    | 11/7 cycles                | 7 cycles     |

<sup>1)</sup> Can be saved by using the interrupt jump table cache (see [Section 7.5](#)).

## Interrupt and Exception Control

### Sources for Additional Delays

Because the service requests are inserted into the current instruction stream, the properties of this instruction stream can influence the request latency.

**Table 7-8 Additional Delays Caused by System Logic**

| Reason for Delay                                                                                                                                                | Interrupt Response                  | PEC Response          |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|-----------------------|
| Interrupt controller busy,<br>because the previous interrupt request<br>is still in process                                                                     | max. 7 cycles                       | max. 7 cycles         |
| Pipeline is stalled,<br>because instructions preceding the<br>injected instruction in the pipeline need<br>to write/read data to/from a peripheral<br>or memory | $2 \times T_{ACCmax}$ <sup>1)</sup> | $2 \times T_{ACCmax}$ |
| Pipeline cancelled,<br>because instructions preceding the<br>injected instruction in the pipeline<br>update core SFRs                                           | 4 cycles                            | 4 cycles              |
| Memory access for stack writes (if not<br>to DPRAM or DSRAM)                                                                                                    | $2/3 \times T_{ACC}$ <sup>2)</sup>  | ---                   |
| Memory access for vector table read<br>(except for intr. jump table cache)                                                                                      | $2 \times T_{ACC}$                  | ---                   |

<sup>1)</sup> This is the longest possible access time within the XC27x5X system.

<sup>2)</sup> Depending on segmentation off/on.

The actual response to an interrupt request may be delayed further depending on programming techniques used by the application. The following factors can contribute:

- Actual interrupt service routine is only reached via a JUMP from the interrupt vector table.  
Time-critical instructions can be placed directly into the interrupt vector table, followed by a branch to the remaining part of the interrupt service routine. The space between two adjacent vectors can be selected via bitfield VECSC in register CPUCON1.
- Context switching is executed before the intended action takes place (see [Section 7.6](#))  
Time-critical instructions can be programmed “non-destructive” and can be executed before switching context for the remaining part of the interrupt service routine.

## 7.14 Interrupt Nodes

### 7.14.1 Physical Interrupt Nodes

The full set of enabled and used modules integrated in the XC27x5X would require more than the 96 interrupt nodes provided by the C166SV2 interrupt controller. Therefore some of the physically available interrupt nodes are shared between selected modules.

The following table summarizes the 96 physical interrupt nodes with their related

- trap number
- vector location
- control register name and address
- node sharing information

**Table 7-9 XC27x5X Interrupt Nodes**

| <b>Source of Interrupt or PEC Service Request</b> | <b>Trap Number</b> | <b>Vector<sup>1)</sup> Location</b> | <b>Control Register</b> | <b>Register Address</b> |
|---------------------------------------------------|--------------------|-------------------------------------|-------------------------|-------------------------|
| selected by ISSR.ISS0                             | 10 <sub>H</sub>    | xx'0040 <sub>H</sub>                | CC2_CC16IC              | F1C0 <sub>H</sub>       |
| selected by ISSR.ISS1                             | 11 <sub>H</sub>    | xx'0044 <sub>H</sub>                | CC2_CC17IC              | F1C2 <sub>H</sub>       |
| selected by ISSR.ISS2                             | 12 <sub>H</sub>    | xx'0048 <sub>H</sub>                | CC2_CC18IC              | F1C4 <sub>H</sub>       |
| selected by ISSR.ISS3                             | 13 <sub>H</sub>    | xx'004C <sub>H</sub>                | CC2_CC19IC              | F1C6 <sub>H</sub>       |
| selected by ISSR.ISS4                             | 14 <sub>H</sub>    | xx'0050 <sub>H</sub>                | CC2_CC20IC              | F1C8 <sub>H</sub>       |
| selected by ISSR.ISS5                             | 15 <sub>H</sub>    | xx'0054 <sub>H</sub>                | CC2_CC21IC              | F1CA <sub>H</sub>       |
| selected by ISSR.ISS6                             | 16 <sub>H</sub>    | xx'0058 <sub>H</sub>                | CC2_CC22IC              | F1CC <sub>H</sub>       |
| selected by ISSR.ISS7                             | 17 <sub>H</sub>    | xx'005C <sub>H</sub>                | CC2_CC23IC              | F1CE <sub>H</sub>       |
| selected by ISSR.ISS8                             | 18 <sub>H</sub>    | xx'0060 <sub>H</sub>                | CC2_CC24IC              | F1D0 <sub>H</sub>       |
| selected by ISSR.ISS9                             | 19 <sub>H</sub>    | xx'0064 <sub>H</sub>                | CC2_CC25IC              | F1D2 <sub>H</sub>       |
| selected by ISSR.ISS10                            | 1A <sub>H</sub>    | xx'0068 <sub>H</sub>                | CC2_CC26IC              | F1D4 <sub>H</sub>       |
| selected by ISSR.ISS11                            | 1B <sub>H</sub>    | xx'006C <sub>H</sub>                | CC2_CC27IC              | F1D6 <sub>H</sub>       |
| selected by ISSR.ISS12                            | 1C <sub>H</sub>    | xx'0070 <sub>H</sub>                | CC2_CC28IC              | F1D8 <sub>H</sub>       |
| selected by ISSR.ISS13                            | 1D <sub>H</sub>    | xx'0074 <sub>H</sub>                | CC2_CC29IC              | F1DA <sub>H</sub>       |
| selected by ISSR.ISS14                            | 1E <sub>H</sub>    | xx'0078 <sub>H</sub>                | CC2_CC30IC              | F1DC <sub>H</sub>       |
| selected by ISSR.ISS15                            | 1F <sub>H</sub>    | xx'007C <sub>H</sub>                | CC2_CC31IC              | F1DE <sub>H</sub>       |
| GPT1 Timer 2                                      | 20 <sub>H</sub>    | xx'0080 <sub>H</sub>                | GPT12E_T2IC             | FF60 <sub>H</sub>       |
| GPT1 Timer 3                                      | 21 <sub>H</sub>    | xx'0084 <sub>H</sub>                | GPT12E_T3IC             | FF62 <sub>H</sub>       |
| GPT1 Timer 4                                      | 22 <sub>H</sub>    | xx'0088 <sub>H</sub>                | GPT12E_T4IC             | FF64 <sub>H</sub>       |

**Interrupt and Exception Control**
**Table 7-9 XC27x5X Interrupt Nodes**

| <b>Source of Interrupt or PEC Service Request</b> | <b>Trap Number</b> | <b>Vector<sup>1)</sup> Location</b> | <b>Control Register</b> | <b>Register Address</b> |
|---------------------------------------------------|--------------------|-------------------------------------|-------------------------|-------------------------|
| GPT2 Timer 5                                      | 23 <sub>H</sub>    | xx'008C <sub>H</sub>                | GPT12E_T5IC             | FF66 <sub>H</sub>       |
| GPT2 Timer 6                                      | 24 <sub>H</sub>    | xx'0090 <sub>H</sub>                | GPT12E_T6IC             | FF68 <sub>H</sub>       |
| GPT2 CAPREL                                       | 25 <sub>H</sub>    | xx'0094 <sub>H</sub>                | GPT12E_CRIC             | FF6A <sub>H</sub>       |
| CAPCOM2 Timer 7                                   | 26 <sub>H</sub>    | xx'0098 <sub>H</sub>                | CC2_T7IC                | FF6C <sub>H</sub>       |
| CAPCOM2 Timer 8                                   | 27 <sub>H</sub>    | xx'009C <sub>H</sub>                | CC2_T8IC                | FF6E <sub>H</sub>       |
| A/D Converter Request 0                           | 28 <sub>H</sub>    | xx'00A0 <sub>H</sub>                | ADC_0IC                 | FF70 <sub>H</sub>       |
| A/D Converter Request 1                           | 29 <sub>H</sub>    | xx'00A4 <sub>H</sub>                | ADC_1IC                 | FF72 <sub>H</sub>       |
| A/D Converter Request 2                           | 2A <sub>H</sub>    | xx'00A8 <sub>H</sub>                | ADC_2IC                 | FF74 <sub>H</sub>       |
| A/D Converter Request 3                           | 2B <sub>H</sub>    | xx'00AC <sub>H</sub>                | ADC_3IC                 | FF76 <sub>H</sub>       |
| A/D Converter Request 4                           | 2C <sub>H</sub>    | xx'00B0 <sub>H</sub>                | ADC_4IC                 | FF78 <sub>H</sub>       |
| A/D Converter Request 5                           | 2D <sub>H</sub>    | xx'00B4 <sub>H</sub>                | ADC_5IC                 | FF7A <sub>H</sub>       |
| A/D Converter Request 6                           | 2E <sub>H</sub>    | xx'00B8 <sub>H</sub>                | ADC_6IC                 | FF7C <sub>H</sub>       |
| A/D Converter Request 7                           | 2F <sub>H</sub>    | xx'00BC <sub>H</sub>                | ADC_7IC                 | FF7E <sub>H</sub>       |
| CCU60 Request 0                                   | 30 <sub>H</sub>    | xx'00C0 <sub>H</sub>                | CCU60_0IC               | F160 <sub>H</sub>       |
| CCU60 Request 1                                   | 31 <sub>H</sub>    | xx'00C4 <sub>H</sub>                | CCU60_1IC               | F162 <sub>H</sub>       |
| CCU60 Request 2                                   | 32 <sub>H</sub>    | xx'00C8 <sub>H</sub>                | CCU60_2IC               | F164 <sub>H</sub>       |
| CCU60 Request 3                                   | 33 <sub>H</sub>    | xx'00CC <sub>H</sub>                | CCU60_3IC               | F166 <sub>H</sub>       |
| CCU61 Request 0                                   | 34 <sub>H</sub>    | xx'00D0 <sub>H</sub>                | CCU61_0IC               | F168 <sub>H</sub>       |
| CCU61 Request 1                                   | 35 <sub>H</sub>    | xx'00D4 <sub>H</sub>                | CCU61_1IC               | F16A <sub>H</sub>       |
| CCU61 Request 2                                   | 36 <sub>H</sub>    | xx'00D8 <sub>H</sub>                | CCU61_2IC               | F16C <sub>H</sub>       |
| CCU61 Request 3                                   | 37 <sub>H</sub>    | xx'00DC <sub>H</sub>                | CCU61_3IC               | F16E <sub>H</sub>       |
| CCU62 Request 0                                   | 38 <sub>H</sub>    | xx'00E0 <sub>H</sub>                | CCU62_0IC               | F170 <sub>H</sub>       |
| CCU62 Request 1                                   | 39 <sub>H</sub>    | xx'00E4 <sub>H</sub>                | CCU62_1IC               | F172 <sub>H</sub>       |
| CCU62 Request 2                                   | 3A <sub>H</sub>    | xx'00E8 <sub>H</sub>                | CCU62_2IC               | F174 <sub>H</sub>       |
| CCU62 Request 3                                   | 3B <sub>H</sub>    | xx'00EC <sub>H</sub>                | CCU62_3IC               | F176 <sub>H</sub>       |
| CCU63 Request 0                                   | 3C <sub>H</sub>    | xx'00F0 <sub>H</sub>                | CCU63_0IC               | F178 <sub>H</sub>       |
| CCU63 Request 1                                   | 3D <sub>H</sub>    | xx'00F4 <sub>H</sub>                | CCU63_1IC               | F17A <sub>H</sub>       |
| CCU63 Request 2                                   | 3E <sub>H</sub>    | xx'00F8 <sub>H</sub>                | CCU63_2IC               | F17C <sub>H</sub>       |
| CCU63 Request 3                                   | 3F <sub>H</sub>    | xx'00FC <sub>H</sub>                | CCU63_3IC               | F17E <sub>H</sub>       |
| CAN0                                              | 40 <sub>H</sub>    | xx'0100 <sub>H</sub>                | CAN_0IC                 | F140 <sub>H</sub>       |

**Interrupt and Exception Control**
**Table 7-9 XC27x5X Interrupt Nodes**

| <b>Source of Interrupt or PEC Service Request</b> | <b>Trap Number</b> | <b>Vector<sup>1)</sup> Location</b> | <b>Control Register</b> | <b>Register Address</b> |
|---------------------------------------------------|--------------------|-------------------------------------|-------------------------|-------------------------|
| CAN1                                              | 41 <sub>H</sub>    | xx'0104 <sub>H</sub>                | CAN_1IC                 | F142 <sub>H</sub>       |
| CAN2                                              | 42 <sub>H</sub>    | xx'0108 <sub>H</sub>                | CAN_2IC                 | F144 <sub>H</sub>       |
| CAN3                                              | 43 <sub>H</sub>    | xx'010C <sub>H</sub>                | CAN_3IC                 | F146 <sub>H</sub>       |
| CAN4                                              | 44 <sub>H</sub>    | xx'0110 <sub>H</sub>                | CAN_4IC                 | F148 <sub>H</sub>       |
| CAN5                                              | 45 <sub>H</sub>    | xx'0114 <sub>H</sub>                | CAN_5IC                 | F14A <sub>H</sub>       |
| CAN6                                              | 46 <sub>H</sub>    | xx'0118 <sub>H</sub>                | CAN_6IC                 | F14C <sub>H</sub>       |
| CAN7                                              | 47 <sub>H</sub>    | xx'011C <sub>H</sub>                | CAN_7IC                 | F14E <sub>H</sub>       |
| CAN8                                              | 48 <sub>H</sub>    | xx'0120 <sub>H</sub>                | CAN_8IC                 | F150 <sub>H</sub>       |
| CAN9                                              | 49 <sub>H</sub>    | xx'0124 <sub>H</sub>                | CAN_9IC                 | F152 <sub>H</sub>       |
| CAN10                                             | 4A <sub>H</sub>    | xx'0128 <sub>H</sub>                | CAN_10IC                | F154 <sub>H</sub>       |
| CAN11                                             | 4B <sub>H</sub>    | xx'012C <sub>H</sub>                | CAN_11IC                | F156 <sub>H</sub>       |
| CAN12                                             | 4C <sub>H</sub>    | xx'0130 <sub>H</sub>                | CAN_12IC                | F158 <sub>H</sub>       |
| CAN13                                             | 4D <sub>H</sub>    | xx'0134 <sub>H</sub>                | CAN_13IC                | F15A <sub>H</sub>       |
| CAN14                                             | 4E <sub>H</sub>    | xx'0138 <sub>H</sub>                | CAN_14IC                | F15C <sub>H</sub>       |
| CAN15                                             | 4F <sub>H</sub>    | xx'013C <sub>H</sub>                | CAN_15IC                | F15E <sub>H</sub>       |
| USIC0 CH0 SR0                                     | 50 <sub>H</sub>    | xx'0140 <sub>H</sub>                | U0C0_0IC                | F120 <sub>H</sub>       |
| USIC0 CH0 SR1                                     | 51 <sub>H</sub>    | xx'0144 <sub>H</sub>                | U0C0_1IC                | F122 <sub>H</sub>       |
| USIC0 CH0 SR2                                     | 52 <sub>H</sub>    | xx'0148 <sub>H</sub>                | U0C0_2IC                | F124 <sub>H</sub>       |
| USIC0 CH1 SR0                                     | 53 <sub>H</sub>    | xx'014C <sub>H</sub>                | U0C1_0IC                | F126 <sub>H</sub>       |
| USIC0 CH1 SR1                                     | 54 <sub>H</sub>    | xx'0150 <sub>H</sub>                | U0C1_1IC                | F128 <sub>H</sub>       |
| USIC0 CH1 SR2                                     | 55 <sub>H</sub>    | xx'0154 <sub>H</sub>                | U0C1_2IC                | F12A <sub>H</sub>       |
| USIC1 CH0 SR0                                     | 56 <sub>H</sub>    | xx'0158 <sub>H</sub>                | U1C0_0IC                | F12C <sub>H</sub>       |
| USIC1 CH0 SR1                                     | 57 <sub>H</sub>    | xx'015C <sub>H</sub>                | U1C0_1IC                | F12E <sub>H</sub>       |
| USIC1 CH0 SR2                                     | 58 <sub>H</sub>    | xx'0160 <sub>H</sub>                | U1C0_2IC                | F130 <sub>H</sub>       |
| USIC1 CH1 SR0                                     | 59 <sub>H</sub>    | xx'0164 <sub>H</sub>                | U1C1_0IC                | F132 <sub>H</sub>       |
| USIC1 CH1 SR1                                     | 5A <sub>H</sub>    | xx'0168 <sub>H</sub>                | U1C1_1IC                | F134 <sub>H</sub>       |
| USIC1 CH1 SR2                                     | 5B <sub>H</sub>    | xx'016C <sub>H</sub>                | U1C1_2IC                | F136 <sub>H</sub>       |
| USIC2 CH0 SR0                                     | 5C <sub>H</sub>    | xx'0170 <sub>H</sub>                | U2C0_0IC                | F138 <sub>H</sub>       |
| USIC2 CH0 SR1                                     | 5D <sub>H</sub>    | xx'0174 <sub>H</sub>                | U2C0_1IC                | F13A <sub>H</sub>       |
| USIC2 CH0 SR2                                     | 5E <sub>H</sub>    | xx'0178 <sub>H</sub>                | U2C0_2IC                | F13C <sub>H</sub>       |

## Interrupt and Exception Control

**Table 7-9 XC27x5X Interrupt Nodes**

| Source of Interrupt or PEC Service Request | Trap Number     | Vector <sup>1)</sup> Location | Control Register | Register Address  |
|--------------------------------------------|-----------------|-------------------------------|------------------|-------------------|
| USIC2 CH1 SR0                              | 5F <sub>H</sub> | xx'017C <sub>H</sub>          | U2C1_0IC         | F13E <sub>H</sub> |
| USIC2 CH1 SR1                              | 60 <sub>H</sub> | xx'0180 <sub>H</sub>          | U2C1_1IC         | F180 <sub>H</sub> |
| USIC2 CH1 SR2                              | 61 <sub>H</sub> | xx'0184 <sub>H</sub>          | U2C1_2IC         | F182 <sub>H</sub> |
| USIC3 CH0 SR0                              | 62 <sub>H</sub> | xx'0188 <sub>H</sub>          | U3C0_0IC         | F184 <sub>H</sub> |
| USIC3 CH0 SR1                              | 63 <sub>H</sub> | xx'018C <sub>H</sub>          | U3C0_1IC         | F186 <sub>H</sub> |
| USIC3 CH0 SR2                              | 64 <sub>H</sub> | xx'0190 <sub>H</sub>          | U3C0_2IC         | F188 <sub>H</sub> |
| USIC3 CH1 SR0                              | 65 <sub>H</sub> | xx'0194 <sub>H</sub>          | U3C1_0IC         | F18A <sub>H</sub> |
| USIC3 CH1 SR1                              | 66 <sub>H</sub> | xx'0198 <sub>H</sub>          | U3C1_1IC         | F18C <sub>H</sub> |
| USIC3 CH1 SR2                              | 67 <sub>H</sub> | xx'019C <sub>H</sub>          | U3C1_2IC         | F18E <sub>H</sub> |
| SCU External Request 0                     | 68 <sub>H</sub> | xx'01A0 <sub>H</sub>          | SCU_ERU_0IC      | F190 <sub>H</sub> |
| SCU External Request 1                     | 69 <sub>H</sub> | xx'01A4 <sub>H</sub>          | SCU_ERU_1IC      | F192 <sub>H</sub> |
| SCU External Request 2                     | 6A <sub>H</sub> | xx'01A8 <sub>H</sub>          | SCU_ERU_2IC      | F194 <sub>H</sub> |
| SCU Interrupt 1                            | 6B <sub>H</sub> | xx'01AC <sub>H</sub>          | SCU_1IC          | F196 <sub>H</sub> |
| SCU Interrupt 0                            | 6C <sub>H</sub> | xx'01B0 <sub>H</sub>          | SCU_0IC          | F198 <sub>H</sub> |
| SCU External Request 3                     | 6D <sub>H</sub> | xx'01B4 <sub>H</sub>          | SCU_ERU_3IC      | F19A <sub>H</sub> |
| RTC                                        | 6E <sub>H</sub> | xx'01B8 <sub>H</sub>          | RTC_IC           | F19C <sub>H</sub> |
| End of PEC Subchannel                      | 6F <sub>H</sub> | xx'01BC <sub>H</sub>          | EOPIC            | F19E <sub>H</sub> |

<sup>1)</sup> Register VECSEG defines the segment where the vector table is located to.

Bitfield VECSC in register CPUCON1 defines the distance between two adjacent vectors. This table represents the default setting, with a distance of 4 (two words) between two vectors.

## Interrupt and Exception Control

### 7.14.2 Interrupt Node Sharing

Interrupt source selection is adjustable to the application focus. The concept described in this chapter allows to adjust the focus to be more on control (CAPCOM2) or on communication (USIC) side.

Interrupt node sharing is controlled by SCU register ISSR (see [Section 7.14.3](#)).

#### Shared Nodes controlled by ISSR

The following figure visualizes the sharing principle controlled by ISSR register. The default interrupt source is CAPCOM2. The alternate source selections are the SCU interrupts 2 and 3 and the SR3 requests of all USIC channels.



**Figure 7-5 Node Sharing Principle controlled by ISSR**

The table below lists the possible selections of interrupt request sources to the physical interrupt nodes (Control Register). Selection is controlled through ISSx bits of the ISSR register.

**Table 7-10 Nodes Sharing controlled by ISSR**

| Control Register | Select Bit | Default Source (ISSx=0) | Alternate Source (ISSx=1) |
|------------------|------------|-------------------------|---------------------------|
| CC2_CC16IC       | ISS0       | CAPCOM2 Request 16      | (not assigned)            |
| CC2_CC17IC       | ISS1       | CAPCOM2 Request 17      | (not assigned)            |
| CC2_CC18IC       | ISS2       | CAPCOM2 Request 18      | USIC3 CH0 SR3             |
| CC2_CC19IC       | ISS3       | CAPCOM2 Request 19      | USIC3 CH1 SR3             |
| CC2_CC20IC       | ISS4       | CAPCOM2 Request 20      | USIC0 CH0 SR3             |
| CC2_CC21IC       | ISS5       | CAPCOM2 Request 21      | USIC0 CH1 SR3             |
| CC2_CC22IC       | ISS6       | CAPCOM2 Request 22      | USIC1 CH0 SR3             |
| CC2_CC23IC       | ISS7       | CAPCOM2 Request 23      | USIC1 CH1 SR3             |

## Interrupt and Exception Control

**Table 7-10 Nodes Sharing controlled by ISSR**

| <b>Control Register</b> | <b>Select Bit</b> | <b>Default Source (ISSx=0)</b> | <b>Alternate Source (ISSx=1)</b> |
|-------------------------|-------------------|--------------------------------|----------------------------------|
| CC2_CC24IC              | ISS8              | CAPCOM2 Request 24             | (not assigned)                   |
| CC2_CC25IC              | ISS9              | CAPCOM2 Request 25             | (not assigned)                   |
| CC2_CC26IC              | ISS10             | CAPCOM2 Request 26             | (not assigned)                   |
| CC2_CC27IC              | ISS11             | CAPCOM2 Request 27             | (not assigned)                   |
| CC2_CC28IC              | ISS12             | CAPCOM2 Request 28             | USIC2 CH0 SR3                    |
| CC2_CC29IC              | ISS13             | CAPCOM2 Request 29             | USIC2 CH1 SR3                    |
| CC2_CC30IC              | ISS14             | CAPCOM2 Request 30             | SCU Interrupt 2                  |
| CC2_CC31IC              | ISS15             | CAPCOM2 Request 31             | SCU Interrupt 3                  |

## Interrupt and Exception Control

### 7.14.3 Interrupt Source Select Registers

In order to map the interrupt request sources in the complete system to the available interrupt nodes, interrupt nodes are shared between selected modules.

#### SCU\_ISSR

##### Interrupt Source Select Register

SFR (FF2EH/97H)

Reset Value: 0000H

| 15        | 14        | 13        | 12        | 11        | 10        | 9        | 8        | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
|-----------|-----------|-----------|-----------|-----------|-----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|
| ISS<br>15 | ISS<br>14 | ISS<br>13 | ISS<br>12 | ISS<br>11 | ISS<br>10 | ISS<br>9 | ISS<br>8 | ISS<br>7 | ISS<br>6 | ISS<br>5 | ISS<br>4 | ISS<br>3 | ISS<br>2 | ISS<br>1 | ISS<br>0 |
| RW        | RW        | RW        | RW        | RW        | RW        | RW       | RW       | RW       | RW       | RW       | RW       | RW       | RW       | RW       | RW       |

| Field | Bits | Type | Description                                                                                                                                                  |
|-------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ISS0  | 0    | rw   | <b>Interrupt Source Select for CC2_CC16IC</b><br>0 <sub>B</sub> CC2 channel 16 interrupt is selected<br>1 <sub>B</sub> Reserved, do not use this combination |
| ISS1  | 1    | rw   | <b>Interrupt Source Select for CC2_CC17IC</b><br>0 <sub>B</sub> CC2 channel 17 interrupt is selected<br>1 <sub>B</sub> Reserved, do not use this combination |
| ISS2  | 2    | rw   | <b>Interrupt Source Select for CC2_CC18IC</b><br>0 <sub>B</sub> CC2 channel 18 interrupt is selected<br>1 <sub>B</sub> USIC3 channel 0 SR3 is selected       |
| ISS3  | 3    | rw   | <b>Interrupt Source Select for CC2_CC19IC</b><br>0 <sub>B</sub> CC2 channel 19 interrupt is selected<br>1 <sub>B</sub> USIC3 channel 1 SR3 is selected       |
| ISS4  | 4    | rw   | <b>Interrupt Source Select for CC2_CC20IC</b><br>0 <sub>B</sub> CC2 channel 20 interrupt is selected<br>1 <sub>B</sub> USIC0 channel 0 SR3 is selected       |
| ISS5  | 5    | rw   | <b>Interrupt Source Select for CC2_CC21IC</b><br>0 <sub>B</sub> CC2 channel 21 interrupt is selected<br>1 <sub>B</sub> USIC0 channel 1 SR3 is selected       |
| ISS6  | 6    | rw   | <b>Interrupt Source Select for CC2_CC22IC</b><br>0 <sub>B</sub> CC2 channel 22 interrupt is selected<br>1 <sub>B</sub> USIC1 channel 0 SR3 is selected       |
| ISS7  | 7    | rw   | <b>Interrupt Source Select for CC2_CC23IC</b><br>0 <sub>B</sub> CC2 channel 23 interrupt is selected<br>1 <sub>B</sub> USIC1 channel 1 SR3 is selected       |

## Interrupt and Exception Control

| Field        | Bits | Type | Description                                                                                                                                                  |
|--------------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ISS8</b>  | 8    | rw   | <b>Interrupt Source Select for CC2_CC24IC</b><br>0 <sub>B</sub> CC2 channel 24 interrupt is selected<br>1 <sub>B</sub> Reserved, do not use this combination |
| <b>ISS9</b>  | 9    | rw   | <b>Interrupt Source Select for CC2_CC25IC</b><br>0 <sub>B</sub> CC2 channel 25 interrupt is selected<br>1 <sub>B</sub> Reserved, do not use this combination |
| <b>ISS10</b> | 10   | rw   | <b>Interrupt Source Select for CC2_CC26IC</b><br>0 <sub>B</sub> CC2 channel 26 interrupt is selected<br>1 <sub>B</sub> Reserved, do not use this combination |
| <b>ISS11</b> | 11   | rw   | <b>Interrupt Source Select for CC2_CC27IC</b><br>0 <sub>B</sub> CC2 channel 27 interrupt is selected<br>1 <sub>B</sub> Reserved, do not use this combination |
| <b>ISS12</b> | 12   | rw   | <b>Interrupt Source Select for CC2_CC28IC</b><br>0 <sub>B</sub> CC2 channel 28 interrupt is selected<br>1 <sub>B</sub> USIC2 channel 0 SR3 is selected       |
| <b>ISS13</b> | 13   | rw   | <b>Interrupt Source Select for CC2_CC29IC</b><br>0 <sub>B</sub> CC2 channel 29 interrupt is selected<br>1 <sub>B</sub> USIC2 channel 1 SR3 is selected       |
| <b>ISS14</b> | 14   | rw   | <b>Interrupt Source Select for CC2_CC30IC</b><br>0 <sub>B</sub> CC2 channel 30 interrupt is selected<br>1 <sub>B</sub> SCU Interrupt 2 is selected           |
| <b>ISS15</b> | 15   | rw   | <b>Interrupt Source Select for CC2_CC31IC</b><br>0 <sub>B</sub> CC2 channel 31 interrupt is selected<br>1 <sub>B</sub> SCU Interrupt 3 is selected           |

## Interrupt and Exception Control

## 7.15 Interrupt and PEC Configuration Registers

The following table lists all registers used to configure the interrupt and PEC behavior of the XC27x5X. Registers are ordered by address. The Interrupt Control registers xxIC, assigned to each interrupt request, are listed separately (see [Section 7.14](#)).

**Bit addressable** SFRs are marked with the letter “**b**” in column “Name”.

**Table 7-11 Register Overview Interrupt and PEC - ordered by address**

| Name             | Physical Address  | 8-bit Address | Description                       | Reset Value       |
|------------------|-------------------|---------------|-----------------------------------|-------------------|
| <b>FINT0CSP</b>  | EC00 <sub>H</sub> | --            | Fast Interrupt 0 CSP Register     | 0000 <sub>H</sub> |
| <b>FINT0ADDR</b> | EC02 <sub>H</sub> | --            | Fast Interrupt 0 Address Register | 0000 <sub>H</sub> |
| <b>FINT1CSP</b>  | EC04 <sub>H</sub> | --            | Fast Interrupt 1 CSP Register     | 0000 <sub>H</sub> |
| <b>FINT1ADDR</b> | EC06 <sub>H</sub> | --            | Fast Interrupt 1 Address Register | 0000 <sub>H</sub> |
| <b>BNKSEL0</b>   | EC20 <sub>H</sub> | --            | Bank Selection Register 0         | 0000 <sub>H</sub> |
| <b>BNKSEL1</b>   | EC22 <sub>H</sub> | --            | Bank Selection Register 1         | 0000 <sub>H</sub> |
| <b>BNKSEL2</b>   | EC24 <sub>H</sub> | --            | Bank Selection Register 2         | 0000 <sub>H</sub> |
| <b>BNKSEL3</b>   | EC26 <sub>H</sub> | --            | Bank Selection Register 3         | 0000 <sub>H</sub> |
| <b>SRCP0</b>     | EC40 <sub>H</sub> | --            | PEC Channel 0 Source Pointer      | 0000 <sub>H</sub> |
| <b>DSTP0</b>     | EC42 <sub>H</sub> | --            | PEC Channel 0 Destination Pointer | 0000 <sub>H</sub> |
| <b>SRCP1</b>     | EC44 <sub>H</sub> | --            | PEC Channel 1 Source Pointer      | 0000 <sub>H</sub> |
| <b>DSTP1</b>     | EC46 <sub>H</sub> | --            | PEC Channel 1 Destination Pointer | 0000 <sub>H</sub> |
| <b>SRCP2</b>     | EC48 <sub>H</sub> | --            | PEC Channel 2 Source Pointer      | 0000 <sub>H</sub> |
| <b>DSTP2</b>     | EC4A <sub>H</sub> | --            | PEC Channel 2 Destination Pointer | 0000 <sub>H</sub> |
| <b>SRCP3</b>     | EC4C <sub>H</sub> | --            | PEC Channel 3 Source Pointer      | 0000 <sub>H</sub> |
| <b>DSTP3</b>     | EC4E <sub>H</sub> | --            | PEC Channel 3 Destination Pointer | 0000 <sub>H</sub> |
| <b>SRCP4</b>     | EC50 <sub>H</sub> | --            | PEC Channel 4 Source Pointer      | 0000 <sub>H</sub> |
| <b>DSTP4</b>     | EC52 <sub>H</sub> | --            | PEC Channel 4 Destination Pointer | 0000 <sub>H</sub> |
| <b>SRCP5</b>     | EC54 <sub>H</sub> | --            | PEC Channel 5 Source Pointer      | 0000 <sub>H</sub> |
| <b>DSTP5</b>     | EC56 <sub>H</sub> | --            | PEC Channel 5 Destination Pointer | 0000 <sub>H</sub> |
| <b>SRCP6</b>     | EC58 <sub>H</sub> | --            | PEC Channel 6 Source Pointer      | 0000 <sub>H</sub> |
| <b>DSTP6</b>     | EC5A <sub>H</sub> | --            | PEC Channel 6 Destination Pointer | 0000 <sub>H</sub> |
| <b>SRCP7</b>     | EC5C <sub>H</sub> | --            | PEC Channel 7 Source Pointer      | 0000 <sub>H</sub> |
| <b>DSTP7</b>     | EC5E <sub>H</sub> | --            | PEC Channel 7 Destination Pointer | 0000 <sub>H</sub> |

## Interrupt and Exception Control

Table 7-11 Register Overview Interrupt and PEC - ordered by address

| Name             | Physical Address  | 8-bit Address   | Description                    | Reset Value       |
|------------------|-------------------|-----------------|--------------------------------|-------------------|
| <b>PECSEG0</b>   | EC80 <sub>H</sub> | --              | PEC Pointer 0 Segment Address  | 0000 <sub>H</sub> |
| <b>PECSEG1</b>   | EC82 <sub>H</sub> | --              | PEC Pointer 1 Segment Address  | 0000 <sub>H</sub> |
| <b>PECSEG2</b>   | EC84 <sub>H</sub> | --              | PEC Pointer 2 Segment Address  | 0000 <sub>H</sub> |
| <b>PECSEG3</b>   | EC86 <sub>H</sub> | --              | PEC Pointer 3 Segment Address  | 0000 <sub>H</sub> |
| <b>PECSEG4</b>   | EC88 <sub>H</sub> | --              | PEC Pointer 4 Segment Address  | 0000 <sub>H</sub> |
| <b>PECSEG5</b>   | EC8A <sub>H</sub> | --              | PEC Pointer 5 Segment Address  | 0000 <sub>H</sub> |
| <b>PECSEG6</b>   | EC8C <sub>H</sub> | --              | PEC Pointer 6 Segment Address  | 0000 <sub>H</sub> |
| <b>PECSEG7</b>   | EC8E <sub>H</sub> | --              | PEC Pointer 7 Segment Address  | 0000 <sub>H</sub> |
| <b>PECISNC b</b> | FFD8 <sub>H</sub> | EC <sub>H</sub> | PEC Interrupt Subnode Control  | 0000 <sub>H</sub> |
| <b>PECC0</b>     | FEC0 <sub>H</sub> | 60 <sub>H</sub> | PEC Channel 0 Control Register | 0000 <sub>H</sub> |
| <b>PECC1</b>     | FEC2 <sub>H</sub> | 61 <sub>H</sub> | PEC Channel 1 Control Register | 0000 <sub>H</sub> |
| <b>PECC2</b>     | FEC4 <sub>H</sub> | 62 <sub>H</sub> | PEC Channel 2 Control Register | 0000 <sub>H</sub> |
| <b>PECC3</b>     | FEC6 <sub>H</sub> | 63 <sub>H</sub> | PEC Channel 3 Control Register | 0000 <sub>H</sub> |
| <b>PECC4</b>     | FEC8 <sub>H</sub> | 64 <sub>H</sub> | PEC Channel 4 Control Register | 0000 <sub>H</sub> |
| <b>PECC5</b>     | FECA <sub>H</sub> | 65 <sub>H</sub> | PEC Channel 5 Control Register | 0000 <sub>H</sub> |
| <b>PECC6</b>     | FECC <sub>H</sub> | 66 <sub>H</sub> | PEC Channel 6 Control Register | 0000 <sub>H</sub> |
| <b>PECC7</b>     | FECE <sub>H</sub> | 67 <sub>H</sub> | PEC Channel 7 Control Register | 0000 <sub>H</sub> |

## 8 System Control Unit (SCU)

The System Control Unit (SCU) of the XC27x5X handles all system control tasks besides the debug related tasks which are controlled by the OCDS/Cerberus. All functions described in this chapter are tightly coupled, thus, they are conveniently handled by one unit, the SCU.

The SCU contains the following functional sub-blocks:

- Clock Generation (see [Chapter 8.1](#))
- System Timer (see [Chapter 8.2](#))
- Wake-up Timer (see [Chapter 8.3](#))
- Reset Operation (see [Chapter 8.4](#))
- External Service Requests (see [Chapter 8.5](#))
- Power Supply and Control (see [Chapter 8.6](#))
- Global State Control (see [Chapter 8.7](#))
- Software Boot Support (see [Chapter 8.8](#))
- External Request Unit (see [Chapter 8.9](#))
- Interrupt Generation (see [Chapter 8.10](#))
- Temperature Compensation (see [Chapter 8.11](#))
- Watchdog Timer (see [Chapter 8.12](#))
- Trap Generation (see [Chapter 8.13](#))
- Memory Content Protection (see [Chapter 8.14](#))
- Register Access Control (see [Chapter 8.15](#))
- Miscellaneous System Registers (see [Chapter 8.16](#))
- SCU Registers and Address map (see [Chapter 8.17](#))

### Important Information: Register Programming

The System Control Unit contains special function registers, which can not be programmed in an arbitrary order in particular due to the usage of an internal voltage regulator. In order to prevent critical system conditions because of an improper setup and to provide means for easy and quick configuration and control of sensitive features such as power supply and clock generation, recommendations and examples for the programming sequence of the registers will be given in the Programmer's Guide.

In particular the registers listed below have to be updated with care:

- Clock Generation Unit: WUOSCCON, HPOSCCON, PLLOSCCON, PLLCONx
- Power Supply: EVR1CON0, EVR1SET15VHP,  
EVRMCON0,EVRMSET15VHP,  
PVC1CON0, PVCMCON0,  
SWDCON0
- System: SYSCON0

## System Control Unit (SCU)

## 8.1 Clock Generation Unit

The Clock Generation Unit (CGU) allows a very flexible clock generation for the XC27x5X. During user program execution the frequency can be programmed for an optimal ratio between performance and power consumption in the actual application state.

### 8.1.1 Overview

The CGU can convert a low-frequency external clock to a high-speed system clock or can create a high-speed system clock without external input.

The CGU consists of a Clock Generator and a Clock Control Unit (CCU).



**Figure 8-1 Clock Generation Unit Block Diagram**

The input connections of the CGU are described in [Chapter 8.18.1](#).

The following clock signals are generated:

- System clock  $f_{SYS}$
- RTC count clock  $f_{RTC}$
- Wake-Up Timer (WUT) clock  $f_{WUT}$
- STM clock  $f_{STM}$
- External clock  $f_{EXT}$

[Chapter 8.1.5](#) and [Chapter 8.1.6](#) describe which clock signals are generated out of which selectable clocks.

## System Control Unit (SCU)

### Register Overview

The CGU is controlled by a number of registers shown in the following figure.



**Figure 8-2 Clock Generation Unit Register Overview**

The following sections describe the different parts of the CGU.

## System Control Unit (SCU)

### 8.1.2 Trimmed Current Controlled Wake-Up Clock (OSC\_WU)

The trimmed current controlled wake-up clock source provides a clock to control internal operations independent of the standard clock supplies and requires no external components. Its output frequency  $f_{WU}$  is configured via bit field **WUOSCCON.FREQSEL** and has a typical range from 130 kHz to 500 kHz.

### 8.1.3 High Precision Oscillator Circuit (OSC\_HP)

The high precision oscillator circuit can drive an external crystal or accepts an external clock source. It consists of an inverting amplifier with XTAL1 as input, and XTAL2 as output.

**Figure 8-4** and **Figure 8-3** show the recommended external circuitries for both operating modes, External Crystal Mode and External Input Clock Mode.

#### 8.1.3.1 External Input Clock Mode

An external clock signal is supplied directly not using an external crystal and bypassing the amplifier of the oscillator. The maximum allowed input frequency depends on the characteristics of pin XTAL1.

When using an external clock signal it must be connected to XTAL1. XTAL2 is left open (unconnected).

*Note: Voltages on XTAL1 must comply to the voltage defined in the data sheet.*



**Figure 8-3 XC27x5X External Clock Input Mode for the High-Precision Oscillator**

#### 8.1.3.2 External Crystal Mode

An external oscillator load circuitry must be used, connected to both pins, XTAL1 and XTAL2. It consists normally of the two load capacitances C1 and C2. For some crystals

## System Control Unit (SCU)

a series damping resistor might be necessary. The exact values and related operating range depend on the crystal and have to be determined and optimized together with the crystal vendor using the negative resistance method.



**Figure 8-4 XC27x5X External Crystal Mode Circuitry for the High-Precision Oscillator**

### Support for Start-up Control of an External Crystal

The first time before the system clock is generated based on an external crystal 1000 cycles of the crystal clock should be waited before the clock control system is changed to External Crystal Mode. Bit **PLLSTAT.OSCLOCK** indicates if the oscillator OSC\_HP operates for at least  $2^{11}$  periods. Bit **PLLSTAT.OSCSTAB** indicates if OSC\_HP operates for at least  $2^{15}$  periods.

### Oscillator Gain Control

The oscillator starts with a high drive level (gain) during and after a Power-on Reset to ensure safe start-up behavior in the beginning (force the crystal oscillation). When a stable oscillation has been reached after oscillation start-up (**PLLSTAT.OSCSTAB** = 1), the gain of the oscillator can be reduced. This reduces the power consumption of the oscillator, which is especially important in the power saving modes. This gain reduction is selected by **HPOSCCON.GAINSEL**.

*Note: Choosing the gain setting is only possible with detailed consideration of parasitics, external circuitry, frequency range and quality of the applied crystal and has to be verified by testing together with the crystal manufacturer.*

### 8.1.4 Phase-Locked Loop (PLL) Module

The PLL can convert a low-frequency external clock signal to a high-speed system clock for maximum performance. The PLL also has fail-safe logic that detects degenerate external clock behavior such as abnormal frequency deviations or a total loss of the external clock. It can execute emergency actions if it loses its lock on the external clock.

This module is a phase locked loop for integer frequency synthesis. It allows the use of input and output frequencies of a wide range by varying the different divider factors.

#### 8.1.4.1 Features

Here is a brief overview of the functions that are offered by the PLL.

- VCO lock detection
- 4-bit input divider **P**: (divide by PDIV+1)
- 6-bit feedback divider **N**: (multiply by NDIV+1)
- 10-bit output divider **K2**: (divide K2DIV+1)
- 10-bit VCO bypass divider **K1**: (divide by either by K1DIV+1)
- Oscillator run detection and Watchdog
- Different operating modes
  - Prescaler Mode
  - Unlocked Mode
  - Normal Mode
- Different power saving modes
  - Power Down
  - Sleep Mode (VCO Power Down)
- Glitchless programming of output divider K2 and VCO bypass divider K1
- Glitchless switching between Normal Mode and Prescaler Mode
- Trimmed current controlled clock source

#### 8.1.4.2 PLL Functional Description

The PLL consists of a Voltage Controlled Oscillator (VCO) with a feedback path. A divider in the feedback path (N-Divider) divides the VCO frequency. The resulting frequency is then compared with the divided external frequency (P-Divider). The phase detection logic determines the difference between the two clocks and accordingly controls the frequency of the VCO ( $f_{VCO}$ ). A PLL lock detection unit monitors and signals this condition. The phase detection logic continues to monitor the two clocks and adjusts the VCO clock if required. The PLL output clock  $f_{PLL}$  is derived from the VCO clock using the K2-Divider or from the oscillator clock using the K1-Divider.

The following figure shows the PLL block structure.

## System Control Unit (SCU)


**Figure 8-5 PLL Block Diagram**

### Clock Source Control

The reference frequency  $f_R$  can be selected to be either taken from the trimmed current controlled clock source  $f_{INT}$  or from an external clock source  $f_{IN}$ .

### PLL Modes

The PLL clock  $f_{PLL}$  is generated from  $f_R$  in one of the following software selectable modes:

- Normal Mode
- Prescaler Mode
- Unlocked Mode

**In Normal Mode** the reference frequency  $f_R$  is divided by a factor P, multiplied by a factor N and then divided by a factor K2. The output frequency is given by

(8.1)

$$f_{PLL} = \frac{N}{P \cdot K2} \cdot f_R$$

## System Control Unit (SCU)

**In Prescaler Mode** the reference frequency  $f_R$  is divided by a factor K1. The output frequency is given by

(8.2)

$$f_{PLL} = \frac{f_R}{K1}$$

**In Unlocked Mode** the base output frequency of the Voltage Controlled Oscillator (VCO)  $f_{VCObase}$  is divided by a factor K2. The output frequency is given by

(8.3)

$$f_{PLL} = \frac{f_{VCObase}}{K2}$$

### PLL Power Saving Modes

**PLL Power Down Mode** The PLL offers a Power Down Mode to save power if the PLL is not needed at all. While the PLL is in Power Down Mode no PLL output frequency is generated.

**PLL Sleep Mode** The PLL offers a Sleep Mode (also called VCO Power Down Mode) to save power within the PLL. While the PLL is in Sleep Mode only the Prescaler Mode can be used.

#### 8.1.4.3 Configuration and Operation of the PLL Modes

The following section describes the configuration and the operation of the different PLL modes. Further information can be found in the Programmer's Guide.

##### Configuration and Operation of the Unlocked Mode

In Unlocked Mode, the PLL is running at its VCO base frequency and  $f_{PLL}$  is derived from  $f_{VCO}$  by the K2-Divider.

## System Control Unit (SCU)


**Figure 8-6 PLL Unlocked Mode Diagram**

The Unlocked Mode is selected by the following settings:

- STATCLR1.SETFINDIS = 1
- PLLCON0.VCOBY = 0

The Unlocked Mode is entered when all following conditions are true:

- PLLSTAT.FINDIS = 1
- PLLSTAT.VCOBYST = 1

Operation in Unlocked Mode does not require an input clock  $f_{IN}$ . The Unlocked Mode is automatically entered on a PLL VCO Loss-of-Lock event if bit PLLCON1.EMFINDISEN is cleared. This mechanism allows a fail-safe operation of the PLL as in emergency cases still a clock is available.

The frequency of the Unlocked Mode  $f_{VCObase}$  is listed in the Data Sheet.

*Note: Changing the system operation frequency by changing the value of the K2-Divider or the VCO range has a direct influence on the power consumption of the device. Therefore, this has to be done carefully.*

### Configuration and Operation of the Normal Mode

In Normal Mode, the PLL is running at frequency  $f_{PLL}$ , where  $f_R$  is divided by a factor P, multiplied by a factor N and then divided by a factor K2.

## System Control Unit (SCU)


**Figure 8-7 PLL Normal Mode Diagram**

The Normal Mode is selected by the following settings:

- PLLCON0.VCOBY = 0
- STATCLR1.CLRFINDIS = 1

The Normal Mode is entered when all following conditions are true:

- PLLSTAT.FINDIS = 0
- PLLSTAT.VCOBYST = 1
- PLLSTAT.VCOLOCK = 1
- HPOSSTCON.PLLV = 1

Operation in Normal Mode requires a clock frequency of  $f_R$ . When  $f_{IN}$  is selected as source for  $f_R$  it is recommended to check and monitor if an input frequency  $f_R$  is available at all by checking HPOSSTCON.PLLV.

The system operation frequency in Normal Mode is controlled by the values of the three dividers: P, N, and K2. A modification of the two dividers P and N has a direct influence on the VCO frequency and leads to a loss of the VCO Lock status. A modification of the K2-divider has no impact on the VCO Lock status but changes the PLL output frequency.

*Note: Changing the system operation frequency by changing the value of the K2-Divider has a direct influence on the power consumption of the device. Therefore, this has to be done carefully.*

To modify or enter the Normal Mode frequency, follow the sequence described below:

Configure and enter Prescaler Mode. For more details see the Prescaler Mode.

Disable the trap generation for the VCO Lost-of-Lock.

## System Control Unit (SCU)

While the Prescaler Mode is used the Normal Mode can be configured and checked for a positive VCO Lock status. The first target frequency of the Normal Mode should be selected in a way that it matches or is only slightly higher as the one used in the Prescaler Mode. This avoids big changes in the system operation frequency and, therefore, the power consumption when switching later from Prescaler Mode to Normal Mode. The P and N dividers should be selected in the following way:

- Selecting P and N in a way that  $f_{VCO}$  is in the lower area of its allowed values leads to a slightly reduced power consumption but to a slightly increased jitter
- Selecting P and N in a way that  $f_{VCO}$  is in the upper area of its allowed values leads to a slightly increased power consumption but to a slightly reduced jitter

After the P, and N dividers are updated for the first configuration, the indication of the VCO Lock status (PLLSTAT.VCOLOCK = 1) should be awaited.

*Note: It is recommended to reset the VCO Lock detection (PLLCON1.RESLD = 1) after the new values of the dividers have been configured to get a defined VCO lock check time.*

When this happens the switch from Prescaler Mode to Normal Mode can be done. Normal Mode is requested by clearing PLLCON0.VCOBY. The Normal Mode is entered when the status bit PLLSTAT.VCOBYST is set.

Now the Normal Mode is entered. The trap status flag for the VCO Lock trap should be cleared and then enabled again.

The intended PLL output target frequency can be configured by changing only the K2-Divider. Depending on the selected divider value of the K2-Divider, the duty cycle of the clock is selected. This can have an impact on the operation with an external communication interface. In order to avoid too big frequency changes it might be necessary to change the K2-Divider in multiple steps. When the value of the K2-Diver was changed the next update of this value should not be done before bit PLLSTAT.K2RDY is set.

*Note: The Programmers's Guide describes a smooth frequency stepping to achieve an appropriate load regulation of the internal voltage regulator.*

### PLL VCO Lock Detection

The PLL has a lock detection that supervises the VCO part of the PLL in order to detect instable VCO circuit behavior. The lock detector marks the VCO circuit and therefore the output  $f_{VCO}$  of the VCO as instable if the two inputs  $f_{REF}$  and  $f_{DIV}$  differ too much. Changes in one or both input frequencies below a level are not marked by a loss of lock because the VCO can handle such small changes without any problem for the system.

### PLL VCO Loss-of-Lock Event

The PLL may become unlocked, caused by a break of the crystal or the external clock line. In such a case, a trap is generated if the according trap is enabled. Additionally, the clock  $f_R$  is disconnected from the PLL VCO to avoid unstable operation due to noise or

## System Control Unit (SCU)

sporadic clock pulses coming from the oscillator circuit. Without a clock input  $f_R$ , the PLL gradually slows down to its VCO base frequency and remains there. The automatic disconnection of the VCO from its input clock  $f_R$  in case of a VCO Loss-of-Lock event can be enabled by setting bit PLLCON1.EMFINDISEN. If this bit is cleared the clock  $f_R$  remains connected to the VCO.

### Configuration and Operation of the Prescaler Mode

In Prescaler Mode, the PLL is running at frequency  $f_{PLL}$ , where  $f_R$  is divided by the K1-Divider.



**Figure 8-8 PLL Prescaler Mode Diagram**

The Prescaler Mode is selected by the following setting:

- PLLCON0.VCOBY = 1

The Prescaler Mode is entered when all following conditions are true:

- PLLSTAT.VCOBYST = 0
- HPOSCCON.PLLV = 1

Operation in Prescaler Mode requires an input clock frequency  $f_R$ . If  $f_{IN}$  is selected as clock source for  $f_R$  it is recommended to check and monitor if an input frequency  $f_{OSC}$  is available at all by checking HPOSCCON.PLLV. There are no requirements regarding the frequency of  $f_R$ .

The system operation frequency in Prescaler Mode is controlled by the value of the K1-Divider. When the value of PLLCON1.K1DIV was changed the next update of this value should not be done before bit PLLSTAT.K1RDY is set.

## System Control Unit (SCU)

*Note: Changing the system operation frequency by changing the value of the K1-Divider has a direct influence on the power consumption of the device. Therefore, this has to be done carefully.*

The duty cycle of the clock signal depends on the selected value of the K1-Divider. This can have an impact for the operation with an external communication interface.

The Prescaler Mode is requested from the Unlocked or Normal Mode by setting bit PLLCON0.VCOBY. The Prescaler Mode is entered when the status bit PLLSTAT.VCOBYST is cleared.

Before the Prescaler Mode is requested the K1-Divider should be configured with a value generating a PLL output frequency  $f_{PLL}$  that matches the one generated by the Unlocked or Normal Mode as much as possible. In this way the frequency change resulting out of the mode change is reduced to a minimum.

The Prescaler Mode is requested to be left by clearing bit PLLCON0.VCOBY. The Prescaler Mode is left when the status bit PLLSTAT.VCOBYST is set.

### Configuration and Operation of the PLL Power Down Mode

The Power Down Mode is entered by setting bit PLLCON0.PLLPWD. While the PLL is in Power Down Mode no PLL output frequency is generated.

### Configuration and Operation of the PLL Sleep Mode

The Sleep Mode (also called VCO Power Down Mode) is entered by setting bit PLLCON0.VCOPWD. While the PLL is in Sleep Mode only the Prescaler Mode is operable. Selecting the Sleep Mode does not automatically switch to the Prescaler Mode. Therefore, before the Sleep Mode is entered the Prescaler Mode must be active.

#### 8.1.4.4 Power Regulator

The analog parts of the PLL (VCO, trimmed current controlled clock source) are running on a dedicated supply generated by a dedicated regulator integrated within the PLL unit.

The regulator has to be enabled separately before the analog blocks of the PLL are activated, i.e. trimmed current controlled clock source and VCO must be kept off until the supply is stable. After activation, the PLL regulator will need its ramp-up time to properly ramp-up the analog PLL supply.

When the regulator shall be disabled in conjunction with a power down of the PLL digital part, it has to be taken into account that the digital part needs an active clock at the output of the PLL to ramp down. In case this clock is generated by one of the PLL oscillators, power down of PLL must be entered before the regulator is disabled. VCO and trimmed current controlled clock source may be activated or switched off together.

### 8.1.4.5 Divider Handshake

The PLL provides several handshake interfaces for dividers. This section describes how a handshake is to be conducted upon a change of configuration.

The general conduction of the handshake is the same for all interfaces. However, a sample sequence is described here in conjunction with re-programming of a divider.

*Note: The described handshake only works if the new setting (e.g. divider value) changes the current value upon the handshake.*

The handshake should be done in the the following steps:

1. Clear acknowledge bit together with setting the new divider value
2. Poll on ready bit to be 0
3. Set acknowledge bit
4. Poll on ready bit to be 1

This approach will even work in case the handshake has not been properly served before, and ready is already at 0 from the beginning. In any case, a change of the divider value will set ready to 0.

### 8.1.4.6 Trimmed Current Controlled Clock

The trimmed current controlled clock source provides a clock  $f_{INT}$  for the PLL. This is configured via bit PLLCON1.OSCSEL.

*Note: The clock  $f_{INT}$  is also required for the operation of the oscillator watchdog.*

### 8.1.4.7 Oscillator Watchdog

The oscillator watchdog continuously monitors the input clock  $f_{IN}$ . If the input frequency becomes too low or if the input clock fails, this oscillator fail condition is indicated by HPOSCCON.PLLV = 0 and an interrupt request is generated.

By setting bit HPOSCCON.OSCWDRST the detection can be restarted without a reset of the complete PLL, e.g. in case of a VCO loss-of-lock condition.

*Note: The oscillator watchdog requires the trimmed current controlled clock  $f_{INT}$  as a reference. Therefore, it can only be used (HPOSCCON.PLLV is valid) while the clock source is active.*

### 8.1.4.8 Switching PLL Parameters

The following restriction applies when changing PLL parameters inside the PLLCON0 to PLLCON3 registers:

- The VCO bypass switch may be used at any time, however, it has to be ensured that the maximum operating frequency of the device (see data sheet) will not be exceeded.
- Prescaler Mode should be selected.
- After switching to Prescaler Mode, NDIV and PDIV can be adjusted.
- Before deselecting the Prescaler Mode, the RESLD bit has to be set and then the VCOLOCK flag has to be checked. Only when the VCOLOCK flag is set again, the Prescaler Mode may be deselected.
- Before changing VCOSEL, the Prescaler Mode must be selected.

*Note: PDIV and NDIV can also be switched in Normal Mode. When changing NDIV, it must be regarded that the VCO clock  $f_{VCO}$  may exceed the target frequency until the PLL becomes locked. After changing PDIV or NDIV, it must be waited for the PLL lock condition. This procedure is typically used for increasing the VCO clock step-by-step.*

## System Control Unit (SCU)

### 8.1.5 Clock Control Unit

The Clock Control Unit (CCU) selects the current clock sources for the clock signals used in the XC27x5X. It generates the following clocks:

- System clock  $f_{\text{SYS}}$
- RTC count clock  $f_{\text{RTC}}$
- WUT clock  $f_{\text{WUT}}$
- System timer clock  $f_{\text{STM}}$
- Output clock  $f_{\text{EXT}}$

The following clock signals can be selected:

- PLL clock  $f_{\text{PLL}}$
- The oscillator clock (OSC\_HP)  $f_{\text{osc}}$
- Wake-up clock  $f_{\text{WU}}$
- Input CLKIN1 as Direct Clock Input  $f_{\text{CLKIN1}}$
- Input CLKIN2 as Direct Clock Input  $f_{\text{CLKIN2}}$

#### 8.1.5.1 Clock Generation

Different clock sources can be selected for the generated clock signals.

*Note: The selected clock sources are affected by the start-up procedure. See chapter Device Status after Start-up for the register values set by the different start-up procedures.*

#### System Clock Generation

The system clock  $f_{\text{SYS}}$  can be selected from the following clock sources in the CCU:

- Wake-up clock  $f_{\text{WU}}$
- The oscillator clock (OSC\_HP)  $f_{\text{osc}}$
- PLL clock  $f_{\text{PLL}}$
- Input CLKIN1 as Direct Clock Input  $f_{\text{CLKIN1}}$

## System Control Unit (SCU)


**Figure 8-9    Clock Control Unit, System Clock Generation**

## System Control Unit (SCU)

**RTC Clock Generation**

For the RTC module it is possible to select the operation in synchronous or asynchronous mode in the module itself. The asynchronous clock for the RTC can be selected out of following clock sources in the CCU:

- PLL clock  $f_{PLL}$
- The oscillator clock (OSC\_HP)  $f_{OSC}$
- Input CLKIN2 as Direct Clock Input  $f_{CLKIN2}$
- Wake-up clock  $f_{WU}$


**Figure 8-10 Clock Control Unit, RTC Clock Generation**

## System Control Unit (SCU)

**System Timer (STM) Clock Generation**

The system timer clock can be selected out of following clock sources:

- The Direct Clock from oscillator  $f_{\text{OSC}}$
- PLL clock  $f_{\text{PLL}}$
- Input CLKIN1 as Direct Clock Input  $f_{\text{CLKIN1}}$
- Input CLKIN2 as Direct Clock Input  $f_{\text{CLKIN2}}$
- Wake-Up Oscillator  $f_{\text{WU}}$

Then the selected clock can be divided by the factor defined in **STMCON.CLKDIV** (see [Chapter 8.2.1.2](#)).



**Figure 8-11 Clock Control Unit, STM Clock Generation**

**System Control Unit (SCU)**
**Wake-up Timer (WUT) Clock Generation**

The wake-up timer clock can be selected out of following clock sources in the CCU:

- Wake-Up Oscillator  $f_{WU}$
- The Direct Clock from oscillator OSC\_HP  $f_{OSC}$
- PLL clock  $f_{PLL}$
- Input CLKIN1 as Direct Clock Input  $f_{CLKIN1}$

Then the selected clock can be divided by the factor defined in [WUCR.CLKDIV](#) (see [Chapter 8.3.2.2](#)).



**Figure 8-12 Clock Control Unit, WUT Clock Generation**

### 8.1.5.2 Selecting and Changing the Operating Frequency

When selecting the clock source and the clock generation method, the required parameters must be carefully written to the respective bit fields, to avoid unintended intermediate states.

Many applications change the frequency of the system clock  $f_{SYS}$  during operation to optimize performance and power consumption of the system. Modifying the operating frequency changes the consumed switching current, which influences the power supply. Therefore, while the core voltage is generated by the on-chip Embedded Voltage Regulators (EVRs), the operating frequency may only be changed according to the rules given in the data sheet.

*Note: To avoid the indicated problems, specific sequences are recommended that ensure the intended operation of the clock system interacting with the power system. Please refer to the document "Programmer's Guide".*

### 8.1.5.3 System Clock Emergency Handling

The generation of the system clock  $f_{SYS}$  can be affected, if either the PLL is no more locked to its input signal  $f_{IN}$ , or if the input clock  $f_{IN}$  is no more active. Both events can be detected and are indicated to the application software. The clock system takes appropriate actions where necessary, so the device and the application is never left without an alternate clock signal.

#### Oscillator Watchdog Event

If the clock frequency of the external source drops below a limit value the oscillator watchdog (OSCWD) (see [Chapter 8.1.4.7](#)) then the clock source for the system clock  $f_{SYS}$  is switched to an alternate clock source, if enabled (HPOSCCON.EMCLKEN = 1). In this case following information is available:

- The oscillator watchdog trap flag (TRAPSTAT.OSCWDTT) is set and a trap request to the CPU is activated, if enabled (TRAPDIS.OSCWDTT = 0).
- Bit HPOSCCON.PLLV = 0, while the clock  $f_{IN}$  is missing
- Bit SYSCON0.EMSOSC is set, if SYSCON0.EMCLKSELEN is set
- The source of the system clock  $f_{SYS}$  is switched to alternate clock source selected by SYSCON0.EMCLKSEL, if enabled (SYSCON0.EMCLKSELEN = 1). This is indicated by bit SYSCON0.SELSTAT = 1.

#### PLL VCO Loss-of-Lock Event

If the PLL output frequency is no longer locked to its input frequency  $f_{IN}$ , the PLL switches from PLL Normal mode to the Unlocked mode, if enabled (PLLCON1.EMFINDISEN = 1). In this case following information is available:

- The PLL VCO loss of lock trap flag (TRAPSTAT.VCOLCKT) is set and a trap request to the CPU is activated, if enabled (TRAPDIS.VCOLCKT = 0).
- Bit PLLSTAT.VCOLOCK = 0, while the PLL is not locked
- Bit SYSCON0.EMSVC0 is set, if SYSCON0.EMCLKSELEN is set
- The PLL VCO clock input is disconnected (PLLSTAT.FINDIS = 1) and the PLL clock slows down to its VCO base frequency.

#### System Behavior

Emergency routines can be executed with the alternate clock (emergency clock or VCO base frequency). The application can then enter a safe status and stop operation, or it can switch to an emergency operating mode, where a reduced performance and/or feature set is provided.

The Programmer's Guide describes both, how to enable these features, and how to react properly on each of the two events.

## System Control Unit (SCU)

### 8.1.6 External Clock Output

An external clock output can be provided via pin EXTCLK to clock an external system or to observe one of the selectable device clocks. This external clock is enabled by setting bit EXTCON.EN and by selecting the clock signal as alternate output function at pin EXTCLK. Following clocks can be selected by EXTCON.SEL for external clock  $f_{EXT}$ :

- System clock  $f_{SYS}$
- Programmable clock output  $f_{OUT}$
- Direct Clock from oscillator OSC\_HP  $f_{OSC}$
- Direct Clock Input  $f_{CLKIN1}$
- PLL clock  $f_{PLL}$
- Wake-up clock  $f_{WU}$
- RTC clock  $f_{RTC}$

*Note: Changing bit field EXTCON.SEL can lead to spikes at pin EXTCLK.*



Figure 8-13 EXTCLK Generation

#### 8.1.6.1 Programmable Frequency Output

The programmable frequency output  $f_{OUT}$  can be selected as clock output (EXTCLK). This clock can be controlled via software, and so can be adapted to the requirements of the connected external circuitry. The programmability also extends the power management to a system level, as also circuitry (peripherals, etc.) outside the XC27x5X can be run at a scalable frequency or can temporarily be left without a clock.

## System Control Unit (SCU)

Clock  $f_{OUT}$  is generated via a reload counter, so the output frequency can be selected in small steps.



**Figure 8-14 Programmable Frequency Output Generation**

$f_{OUT}$  always provides complete output periods (provided  $f_{SYS}$  is available):

- When  $f_{OUT}$  is started (**EXTCON.FOEN** is set) counter FOCNT is loaded from **EXTCON.FORV**
- When OUT is stopped (**EXTCON.FOEN** is cleared) counter FOCNT is stopped when  $f_{OUT}$  has reached (or is) '0'.

Register EXTCON provides control over the output generation (frequency, waveform, activation) as well as all status information (**EXTCON.FOTL**).

## System Control Unit (SCU)


**Figure 8-15 Output Waveforms Examples**

*Note: The output (for EXTCON.FOSS= 1) is high for the duration of one  $f_{\text{SYS}}$  cycle for all reload values EXTCON.FORV > 0. For EXTCON.FORV = 0 the output frequency corresponds to  $f_{\text{SYS}}$ .*

*When a reference clock is required (e.g. for the bus interface),  $f_{\text{SYS}}$  must be selected directly.*

## 8.1.7 CGU Registers

### **8.1.7.1 Wake-up Clock Register**

This register controls the settings of OSC\_WU.

WUOSCCON

## Wake-up OSC Control Register ESFR (F1AE<sub>H</sub>/D7<sub>H</sub>)

**Reset Value: 0000<sub>H</sub>**

The diagram shows a register map with bit fields. The bits are numbered from 15 down to 0. The bit field for bit 10 is labeled '0'. The bit fields for bits 4, 3, and 2 are grouped together and labeled 'DIS'. The bit fields for bits 1 and 0 are grouped together and labeled 'FREQSEL'.

| Field          | Bits   | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|--------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>FREQSEL</b> | [1:0]  | rw   | <p><b>Frequency Selection</b></p> <p>00<sub>B</sub> <math>f_{WU}</math> is approximately 500 kHz<br/>           01<sub>B</sub> <math>f_{WU}</math> is approximately 300 kHz<br/>           10<sub>B</sub> <math>f_{WU}</math> is approximately 200 kHz<br/>           11<sub>B</sub> <math>f_{WU}</math> is approximately 130 kHz</p> <p><i>Note: This value must not be changed while <math>f_{WU}</math> is used as clock source for any logic.</i></p> |
| <b>0</b>       | [3:2]  | rw   | <p><b>Reserved</b></p> <p>Must be written with reset value 00<sub>B</sub>.</p>                                                                                                                                                                                                                                                                                                                                                                            |
| <b>DIS</b>     | 4      | rw   | <p><b>Clock Disable</b></p> <p>0<sub>B</sub> The oscillator is switched on and the clock is enabled<br/>           1<sub>B</sub> The oscillator is swiched off and the clock is disabled</p>                                                                                                                                                                                                                                                              |
| <b>0</b>       | [15:5] | r    | <p><b>Reserved</b></p> <p>Read as 0; should be written with 0.</p>                                                                                                                                                                                                                                                                                                                                                                                        |

## System Control Unit (SCU)

### 8.1.7.2 High Precision Oscillator Register

This register controls the setting of OSC\_HP.

#### HPOSCCON

#### High Precision OSC Control Register

| ESFR (F1B4 <sub>H</sub> /DA <sub>H</sub> ) |    |    |                 |                 |                      |                  |              |               |            |                |             |                    |              |   | Reset Value: 053C <sub>H</sub> |  |
|--------------------------------------------|----|----|-----------------|-----------------|----------------------|------------------|--------------|---------------|------------|----------------|-------------|--------------------|--------------|---|--------------------------------|--|
| 15                                         | 14 | 13 | 12              | 11              | 10                   | 9                | 8            | 7             | 6          | 5              | 4           | 3                  | 2            | 1 | 0                              |  |
|                                            |    |    |                 |                 |                      |                  |              |               |            |                |             |                    |              |   |                                |  |
|                                            |    |    | <b>OSC 2 L0</b> | <b>OSC 2 L1</b> | <b>EM FIN DIS EN</b> | <b>EM CLK EN</b> | <b>SH BY</b> | <b>X1D EN</b> | <b>X1D</b> | <b>GAINSEL</b> | <b>MODE</b> | <b>OSC WDT RST</b> | <b>PLL V</b> |   |                                |  |
| r                                          |    |    | rh              | rh              | rw                   | rw               | rw           | rw            | rh         | rw             | rw          | rw                 | w            |   | rh                             |  |

| Field            | Bits  | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>PLLV</b>      | 0     | rh   | <b>Oscillator for PLL Valid Status Bit</b><br>This bit indicates whether the frequency output of OSC_HP is usable.<br>This is checked by the Oscillator Watchdog of the PLL.<br>0 <sub>B</sub> The OSC_HP frequency is not usable. The frequency is below the limit.<br>1 <sub>B</sub> The OSC_HP frequency is usable. The frequency is not below the limit.<br>For more information see <a href="#">Chapter 8.1.4.7</a> . |
| <b>OSCWDTRST</b> | 1     | w    | <b>Oscillator Watchdog Reset</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> The Oscillator Watchdog of the PLL is reset and restarted                                                                                                                                                                                                                                                                                   |
| <b>MODE</b>      | [3:2] | rw   | <b>Oscillator Mode</b><br>00 <sub>B</sub> The oscillator is active (crystal or ext. input)<br>01 <sub>B</sub> Reserved, do not use<br>10 <sub>B</sub> Reserved, do not use<br>11 <sub>B</sub> OSC_HP is disabled and in power-saving mode                                                                                                                                                                                  |
| <b>GAINSEL</b>   | [5:4] | rw   | <b>Oscillator Gain Selection</b><br>00 <sub>B</sub> Supply current is typically 300 µA (not tested)<br>01 <sub>B</sub> Supply current is typically 530 µA (not tested)<br>10 <sub>B</sub> Supply current is typically 450 µA (not tested)<br>11 <sub>B</sub> Supply current is typically 610 µA (not tested)                                                                                                               |

## System Control Unit (SCU)

| Field      | Bits | Type | Description                                                                                                                                                                                                                                                                                                              |
|------------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| X1D        | 6    | rh   | <b>XTAL1 Data Value</b><br>This bit reflects the inverted level of pin XTAL1.<br>This bit is sampled with $f_{SYS}$ while X1DEN is set.<br><i>Note: Voltages on XTAL1 must comply to the voltage defined in the data sheet.</i>                                                                                          |
| X1DEN      | 7    | rw   | <b>XTAL1 Data Enable</b><br>$0_B$ Bit X1D is not updated<br>$1_B$ Bit X1D can be updated                                                                                                                                                                                                                                 |
| SHBY       | 8    | rw   | <b>Shaper Bypass</b><br>The shaper forms a proper signal from the input signal. This bit must be 0 for proper operation.<br>$0_B$ The shaper is not bypassed<br>$1_B$ The shaper is bypassed                                                                                                                             |
| EMCLKEN    | 9    | rw   | <b>OSCWDT Emergency System Clock Source Select Enable</b><br>This bit requests the master clock multiplexer (MCM) to switch to an alternate clock (selected by bit field SYSCON0.EMCLKSEL) in an OSCWDT emergency case.<br>$0_B$ MCM remains controlled by SYSCON0.CLKSEL<br>$1_B$ MCM is controlled by SYSCON0.EMCLKSEL |
| EMFINDISEN | 10   | rw   | <b>Emergency Input Clock Disconnect Enable</b><br>This bit defines if bit PLLSTAT.FINDIS is set in an OSCWDT emergency case.<br>$0_B$ No action<br>$1_B$ PLLSTAT.FINDIS is set in an emergency case<br><i>Note: Please refer to the Programmer's Guide for a description of the proper handling.</i>                     |
| OSC2L1     | 11   | rh   | <b>OSC_HP Not Usable Frequency Event</b><br>This sticky bit indicates if bit PLLV has been cleared since OSC2L1 has last been cleared (by writing 1 to bit STATCLR1.OSC2L1CLR).<br>$0_B$ No change of PLLV detected<br>$1_B$ Bit PLLV has been cleared at least once                                                     |

## System Control Unit (SCU)

| Field         | Bits    | Type | Description                                                                                                                                                                                                                                                            |
|---------------|---------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>OSC2L0</b> | 12      | rh   | <b>OSC_HP Usable Frequency Event</b><br>This sticky bit indicates if bit PLLV has been set since OSC2L0 has last been cleared (by writing 1 to bit STATCLR1.OSC2L0CLR).<br>0 <sub>B</sub> No change of PLLV detected<br>1 <sub>B</sub> PLLV has been set at least once |
| <b>0</b>      | [15:13] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                |

### 8.1.7.3 PLL Control Register

This register controls the trimmed current controlled clock source.

#### PLLOSCCON

#### PLL OSC Control Register

| ESFR (F1B6 <sub>H</sub> /DB <sub>H</sub> ) |    |    |    |    |    |   |   |   |   |         |   |   |   |   |   | Reset Value: 0000 <sub>H</sub> |
|--------------------------------------------|----|----|----|----|----|---|---|---|---|---------|---|---|---|---|---|--------------------------------|
| 15                                         | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5       | 4 | 3 | 2 | 1 | 0 |                                |
| 0                                          |    |    |    |    |    |   |   |   |   | OSCTRIM |   |   |   |   |   | OSC PD                         |
| r                                          |    |    |    |    |    |   |   |   |   | rw      |   |   |   |   |   | rw                             |

| Field   | Bits    | Type | Description                                                                                                                                                                                   |
|---------|---------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OSCPD   | 0       | rw   | <b>Clock Source Power Saving Mode</b><br>0 <sub>B</sub> Trimmed current controlled clock source is active<br>1 <sub>B</sub> Trimmed current controlled clock source is off                    |
| OSCTRIM | [9:1]   | rw   | <b>Clock Source Trim Configuration</b><br>This value is used to adjust the frequency range of the current controlled clock source.<br>Do not change this value when writing to this register. |
| 0       | [15:10] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                       |

## System Control Unit (SCU)

## 8.1.7.4 PLL Registers

These registers control the settings of the PLL.

**PLLSTAT**
**PLL Status Register**
**ESFR (F0BC<sub>H</sub>/5E<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**

| 15               | 14               | 13       | 12               | 11            | 10            | 9              | 8             | 7             | 6            | 5            | 4        | 3                | 2                 | 1                | 0                |
|------------------|------------------|----------|------------------|---------------|---------------|----------------|---------------|---------------|--------------|--------------|----------|------------------|-------------------|------------------|------------------|
| <b>OSC LOC K</b> | <b>OSC STA B</b> | <b>0</b> | <b>REG STA T</b> | <b>VCO L1</b> | <b>VCO L0</b> | <b>FIN DIS</b> | <b>K2 RDY</b> | <b>K1 RDY</b> | <b>N RDY</b> | <b>P RDY</b> | <b>0</b> | <b>VCO LOC K</b> | <b>OSC SEL ST</b> | <b>PWD STA T</b> | <b>VCO BY ST</b> |
| rh               | rh               | r        | rh               | rh            | rh            | rh             | rh            | rh            | rh           | rh           | r        | rh               | rh                | rh               | rh               |

| Field           | Bits | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>VCOBYST</b>  | 0    | rh   | <b>VCO Bypass Status</b><br>$0_B$ The PLL clock is derived from divider K1 (Prescaler Mode)<br>$1_B$ The PLL clock is derived from divider K2 (Normal / Unlocked Mode)<br><i>Note: Coding of PLLCON0.VCOBY and VCOBYST are different.</i>                                                                                                                                                                                            |
| <b>PWDSTAT</b>  | 1    | rh   | <b>PLL Power-saving Mode Status</b><br>$0_B$ The PLL is operable<br>$1_B$ The digital part of the PLL is disabled                                                                                                                                                                                                                                                                                                                    |
| <b>OSCSELST</b> | 2    | rh   | <b>Oscillator Input Selection Status</b><br>$0_B$ External input clock source for the PLL ( $f_{IN}$ )<br>$1_B$ Internal input clock source for the PLL                                                                                                                                                                                                                                                                              |
| <b>VCOLOCK</b>  | 3    | rh   | <b>PLL VCO Lock Status</b><br>$0_B$ The frequency difference of $f_{REF}$ and $f_{DIV}$ is greater than allowed. The PLL cannot lock.<br>$1_B$ The PLL clock $f_{PLL}$ is locked to $f_{REF}$ and is stable.<br><i>Note: In case of a loss of lock, the VCO frequency <math>f_{VCO}</math> approaches to the upper/lower boundary of the selected VCO band if the reference frequency is higher/lower than possible for locking.</i> |

## System Control Unit (SCU)

| Field  | Bits | Type | Description                                                                                                                                                                                                                                                                      |
|--------|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PRDY   | 5    | rh   | <b>P-Divider Ready Status</b><br>$0_B$ Bit field PLLCON1.PDIV has been changed,<br>new K1 divider value not yet used.<br>$1_B$ The P-Divider operates with the value defined<br>in bit field PLLCON1.PDIV.                                                                       |
| NRDY   | 6    | rh   | <b>N-Divider Ready Status</b><br>$0_B$ Bit field PLLCON0.NDIV has been changed,<br>new K1 divider value not yet used.<br>$1_B$ The P-Divider operates with the value defined<br>in bit field PLLCON0.NDIV.                                                                       |
| K1RDY  | 7    | rh   | <b>K1-Divider Ready Status</b><br>$0_B$ Bit field PLLCON2.K1DIV has been changed,<br>new K1 divider value not yet used.<br>$1_B$ The K1-Divider operates with the value defined<br>in bit field PLLCON2.K1DIV.                                                                   |
| K2RDY  | 8    | rh   | <b>K2-Divider Ready Status</b><br>$0_B$ Bit field PLLCON3.K2DIV has been changed,<br>new K2 divider value not yet used.<br>$1_B$ The K2-Divider operates with the value defined<br>in bit field PLLCON3.K2DIV.                                                                   |
| FINDIS | 9    | rh   | <b>Input Clock Disconnect Select Status</b><br>$0_B$ The VCO is connected to the reference clock<br>$1_B$ The VCO is disconnected from the reference<br>clock<br><i>Note: Software can control this bit by writing 1 to bits SETFINDIS or CLRFINDIS in register STATCLR1.</i>    |
| VCOL0  | 10   | rh   | <b>VCO Lock Detection Lost Status</b><br>This sticky bit indicates if bit VCOLOCK has been cleared since VCOL0 has last been cleared (by writing 1 to bit STATCLR1.VCOL0CLR).<br>$0_B$ No falling edge detected<br>$1_B$ PLLV has been cleared at least once (VCO lock was lost) |

## System Control Unit (SCU)

| Field            | Bits  | Type | Description                                                                                                                                                                                                                                                                                                       |
|------------------|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>VCOL1</b>     | 11    | rh   | <b>VCO Lock Detection Reached Status</b><br>This sticky bit indicates if bit VCOLOCK has been set since VCOL1 has last been cleared (by writing 1 to bit STATCLR1.VCOL1CLR).<br>0 <sub>B</sub> No rising edge detected<br>1 <sub>B</sub> VCO lock was reached                                                     |
| <b>REGSTAT</b>   | 12    | rh   | <b>PLL Power Regulator Status</b><br>The PLL is powered by a separate internal regulator.<br>0 <sub>B</sub> The PLL is not powered (off)<br>1 <sub>B</sub> The PLL is powered (operation possible)<br><i>Note: Software can control this bit by writing 1 to bits REGENSET or REGENCLR in register PLLCON0.</i>   |
| <b>OSCSTAB</b>   | 14    | rh   | <b>OSC_HP Stable</b><br>0 <sub>B</sub> The oscillator is starting up. None or less than 2 <sup>15</sup> clock cycles have been counted<br>1 <sub>B</sub> At least 2 <sup>15</sup> clock cycles have been counted<br><i>Note: This bit is cleared when HPOSCCON.MODE is 1X<sub>B</sub>.</i>                        |
| <b>OSCLKLOCK</b> | 15    | rh   | <b>OSC_HP Lock</b><br>0 <sub>B</sub> The oscillator is unlocked. None or less than 2 <sup>11</sup> clock cycles have been counted.<br>1 <sub>B</sub> The oscillator is locked. At least 2 <sup>11</sup> clock cycles have been counted.<br><i>Note: This bit is cleared when HPOSCCON.MODE is 1X<sub>B</sub>.</i> |
| <b>0</b>         | 4, 13 | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                           |

## System Control Unit (SCU)

**STATCLR1**
**PLL Status Clear 1 Register**
**ESFR (F0E2<sub>H</sub>/71<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5          | 4          | 3          | 2          | 1          | 0          |
|----|----|----|----|----|----|---|---|---|---|------------|------------|------------|------------|------------|------------|
|    |    |    |    |    |    |   |   |   |   | <b>CLR</b> | <b>SET</b> | <b>OSC</b> | <b>OSC</b> | <b>VCO</b> | <b>VCO</b> |
| 0  |    |    |    |    |    |   |   |   |   |            |            |            |            |            |            |
|    |    |    |    |    |    |   |   |   |   | <b>FIN</b> | <b>FIN</b> | <b>2L0</b> | <b>2L1</b> | <b>L1</b>  | <b>L0</b>  |
|    |    |    |    |    |    |   |   |   |   | <b>DIS</b> | <b>DIS</b> | <b>CLR</b> | <b>CLR</b> | <b>CLR</b> | <b>CLR</b> |
|    |    |    |    |    |    |   |   |   |   | <b>W</b>   | <b>W</b>   | <b>W</b>   | <b>W</b>   | <b>W</b>   | <b>W</b>   |
| r  |    |    |    |    |    |   |   |   |   |            |            |            |            |            |            |

| Field            | Bits   | Type | Description                                                                                                                                           |
|------------------|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>VCOL0CLR</b>  | 0      | w    | <b>VCOL0 Clear Trigger</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit PLLSTAT.VCOL0 is cleared                                                 |
| <b>VCOL1CLR</b>  | 1      | w    | <b>VCOL1 Clear Trigger</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit PLLSTAT.VCOL1 is cleared                                                 |
| <b>OSC2L1CLR</b> | 2      | w    | <b>OSC2L1 Clear Trigger</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bits HPOSCCON.OSC2L1 is cleared                                             |
| <b>OSC2L0CLR</b> | 3      | w    | <b>OSC2L0 Clear Trigger</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit HPOSCCON.OSC2L0 is cleared                                              |
| <b>SETFINDIS</b> | 4      | w    | <b>Set Status Bit PLLSTAT.FINDIS</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit PLLSTAT.FINDIS is set. The VCO input clock is disconnected.    |
| <b>CLRFINDIS</b> | 5      | w    | <b>Clear Status Bit PLLSTAT.FINDIS</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit PLLSTAT.FINDIS is cleared. The VCO input clock is connected. |
| <b>0</b>         | [15:6] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                               |

## System Control Unit (SCU)

**PLLCON0**
**PLL Configuration 0 Register    ESFR (F1B8<sub>H</sub>/DC<sub>H</sub>)    Reset Value: 1302<sub>H</sub>**

| 15       | 14 | 13 | 12 | 11 | 10 | 9    | 8 | 7 | 6         | 5                | 4                | 3      | 2          | 1         | 0 |
|----------|----|----|----|----|----|------|---|---|-----------|------------------|------------------|--------|------------|-----------|---|
| N<br>ACK | 0  |    |    |    |    | NDIV |   | 0 | IN<br>SEL | REG<br>EN<br>SET | REG<br>EN<br>CLR | VCOSEL | VCO<br>PWD | VCO<br>BY |   |
| rw       | r  |    |    |    |    | rw   |   | r | rw        | w                | w                | rw     | rw         | rw        |   |

| Field    | Bits  | Type | Description                                                                                                                                                                                                                                                                                              |
|----------|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VCOBY    | 0     | rw   | <b>VCO Bypass</b><br>$0_B$ Select divider K2 for PLL clock<br>(Normal / Unlocked Mode)<br>$1_B$ Select divider K1 for PLL clock<br>(Prescaler Mode, i.e. VCO is bypassed)<br>Bit PLLSTAT.VCOBYST shows the actually selected divider.<br><i>Note: Coding of VCOBY and PLLSTAT.VCOBYST are different.</i> |
| VCOPWD   | 1     | rw   | <b>VCO Power Saving Mode</b><br>$0_B$ Normal behavior<br>$1_B$ The VCO is put into a power saving mode and can no longer be used. Only the Prescaler Mode is active if previously selected.                                                                                                              |
| VCOSEL   | [3:2] | rw   | <b>VCO Range Select</b><br>The values for the different settings are listed in the data sheet.                                                                                                                                                                                                           |
| REGENCLR | 4     | w    | <b>Power Regulator Enable Clear</b><br>$0_B$ No action<br>$1_B$ Switch off the PLL's power regulator.<br>The PLL is not powered (no operation possible).                                                                                                                                                 |
| REGENSET | 5     | w    | <b>Power Regulator Enable Set</b><br>$0_B$ No action<br>$1_B$ Switch on the PLL's power regulator.<br>The PLL is powered (operation possible).                                                                                                                                                           |
| INSEL    | 6     | rw   | <b>Input Select</b><br>$0_B$ $f_{OSC}$ is selected as input for the PLL<br>$1_B$ $f_{CLKIN1}$ is selected as input for the PLL                                                                                                                                                                           |

System Control Unit (SCU)

| Field       | Bits   | Type | Description                                                                                                                                                                                                                                                                                                |
|-------------|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>NDIV</b> | [13:8] | rw   | <b>N-Divider Value</b><br>The value the N-Divider operates is NDIV+1.<br>Only values between N = 8 and N = 28 are allowed for VCOSEL = 00 <sub>B</sub> .<br>Only values between N = 16 and N = 40 are allowed for VCOSEL = 01 <sub>B</sub> .<br>Outside of this range, stable operation cannot be ensured. |
| <b>NACK</b> | 15     | rw   | <b>N-Divider Ready Acknowledge</b><br>Setting this bit provides the acknowledge signal to NRDY.                                                                                                                                                                                                            |
| <b>0</b>    | 7, 14  | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                    |

## System Control Unit (SCU)

**PLLCON1**
**PLL Configuration 1 Register    ESFR (F1BA<sub>H</sub>/DD<sub>H</sub>)    Reset Value: 000A<sub>H</sub>**

| 15       | 14 | 13 | 12 | 11 | 10   | 9 | 8 | 7 | 6                      | 5               | 4 | 3               | 2         | 1          | 0          |
|----------|----|----|----|----|------|---|---|---|------------------------|-----------------|---|-----------------|-----------|------------|------------|
| P<br>ACK | 0  |    |    |    | PDIV |   |   | 0 | EM<br>FIN<br>DIS<br>EN | EM<br>CLK<br>EN | 0 | A<br>OSC<br>SEL | RES<br>LD | OSC<br>SEL | PLL<br>PWD |

rw                      r                      rw                      r                      rw                      rw                      r                      rw                      w                      rw                      rw

| Field          | Bits | Type | Description                                                                                                                                                                                                                                                                                                             |
|----------------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>PLLPWD</b>  | 0    | rw   | <b>PLL Power Saving Mode</b><br>$0_B$ Normal behavior<br>$1_B$ Complete PLL block is put into a power saving mode and no longer operates                                                                                                                                                                                |
| <b>OSCSEL</b>  | 1    | rw   | <b>Oscillator Input Selection</b><br>$0_B$ Select external clock as input for PLL<br>$1_B$ Select trimmed current controlled clock as input for PLL                                                                                                                                                                     |
| <b>RESLD</b>   | 2    | w    | <b>Restart VCO Lock Detection</b><br>Setting this bit will reset bit PLLSTAT.VCOLOCK and restart the VCO lock detection.                                                                                                                                                                                                |
| <b>AOSCSEL</b> | 3    | rw   | <b>Asynchronous Oscillator Input Selection</b><br>This bit overrules the setting of bit OSCSEL.<br>$0_B$ Configuration is controlled via bit OSCSEL<br>$1_B$ Select asynchronously trimmed current controlled clock as input for PLL                                                                                    |
| <b>EMCLKEN</b> | 5    | rw   | <b>VCOLCK Emergency System Clock Source Select Enable</b><br>This bit requests the master clock multiplexer (MCM) to switch to an alternate clock (selected by bit field SYSCON0.EMCLKSEL) in a VCOLCK emergency case.<br>$0_B$ MCM remains controlled by SYSCON0.CLKSEL<br>$1_B$ MCM is controlled by SYSCON0.EMCLKSEL |

## System Control Unit (SCU)

| Field             | Bits             | Type | Description                                                                                                                                                                                                                                                                                                                 |
|-------------------|------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>EMFINDISEN</b> | 6                | rw   | <b>Emergency Input Clock Disconnect Enable</b><br>This bit defines if bit PLLSTAT.FINDIS is set in a VCOLCK emergency case.<br>0 <sub>B</sub> No action<br>1 <sub>B</sub> PLLSTAT.FINDIS is set in a VCOLCK emergency case<br><i>Note: Please refer to the Programmer's Guide for a description of the proper handling.</i> |
| <b>PDIV</b>       | [11:8]           | rw   | <b>P-Divider Value</b><br>The value the P-Divider operates is PDIV+1.                                                                                                                                                                                                                                                       |
| <b>PACK</b>       | 15               | rw   | <b>P-Divider Ready Acknowledge</b><br>Setting this bit provides the acknowledge to PRDY.                                                                                                                                                                                                                                    |
| <b>0</b>          | 4, 7,<br>[14:12] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                     |

## System Control Unit (SCU)

**PLLCON2**
**PLL Configuration 2 Register    ESFR (F1BC<sub>H</sub>/DE<sub>H</sub>)**
**Reset Value: 0001<sub>H</sub>**

| 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5     | 4 | 3 | 2 | 1 | 0 |
|-----------|----|----|----|----|----|---|---|---|---|-------|---|---|---|---|---|
| K1<br>ACK |    |    | 0  |    |    |   |   |   |   | K1DIV |   |   |   |   |   |

| Field | Bits    | Type | Description                                                                                             |
|-------|---------|------|---------------------------------------------------------------------------------------------------------|
| K1DIV | [9:0]   | rw   | <b>K1-Divider Value</b><br>The value the K1-Divider operates is K1DIV+1.                                |
| K1ACK | 15      | rw   | <b>K1-Divider Ready Acknowledge<sup>1)</sup></b><br>Setting this bit provides the acknowledge to K1RDY. |
| 0     | [14:10] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                 |

<sup>1)</sup> Please refer to the Programmer's Guide for a description of the proper handling.

## System Control Unit (SCU)

**PLLCON3**
**PLL Configuration 3 Register    ESFR (F1BE<sub>H</sub>/DF<sub>H</sub>)    Reset Value: 00CB<sub>H</sub>**

|              |          |    |    |    |    |              |   |   |   |   |   |   |   |   |   |
|--------------|----------|----|----|----|----|--------------|---|---|---|---|---|---|---|---|---|
| 15           | 14       | 13 | 12 | 11 | 10 | 9            | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| <b>K2ACK</b> | 0        |    |    |    |    | <b>K2DIV</b> |   |   |   |   |   |   |   |   |   |
| <b>rw</b>    | <b>r</b> |    |    |    |    | <b>rw</b>    |   |   |   |   |   |   |   |   |   |

| Field        | Bits    | Type      | Description                                                                                              |
|--------------|---------|-----------|----------------------------------------------------------------------------------------------------------|
| <b>K2DIV</b> | [9:0]   | <b>rw</b> | <b>K2-Divider Value</b><br>The value the K2-Divider operates is K2DIV+1.                                 |
| <b>K2ACK</b> | 15      | <b>rw</b> | <b>K2-Divider Ready Acknowledge</b> <sup>1)</sup><br>Setting this bit provides the acknowledge to K2RDY. |
| <b>0</b>     | [14:10] | <b>r</b>  | <b>Reserved</b><br>Read as 0; should be written with 0.                                                  |

<sup>1)</sup> Please refer to the Programmer's Guide for a description of the proper handling.

## System Control Unit (SCU)

### 8.1.7.5 System Clock Control Registers

These registers control the system level clock behavior.

#### SYSCON0

**System Control 0 Register      SFR (FF4A<sub>H</sub>/A5<sub>H</sub>)      Reset Value: 0000<sub>H</sub>**

| 15              | 14 | 13         | 12         | 11            | 10 | 9             | 8 | 7                      | 6 | 5            | 4 | 3 | 2      | 1 | 0 |
|-----------------|----|------------|------------|---------------|----|---------------|---|------------------------|---|--------------|---|---|--------|---|---|
| SEL<br>STA<br>T | 0  | EMS<br>VCO | EMS<br>OSC | STM<br>CLKSEL |    | WUT<br>CLKSEL |   | EM<br>CLK<br>SEL<br>EN | 0 | EM<br>CLKSEL |   | 0 | CLKSEL |   |   |

rh r rh rh rw rw rw r rw r rw r rw

| Field      | Bits  | Type | Description                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CLKSEL     | [1:0] | rw   | <b>Clock Select</b><br>This bit field defines the clock source that is used as system clock for normal operation.<br>00 <sub>B</sub> The Wake-up clock $f_{WU}$ is used<br>01 <sub>B</sub> The oscillator clock (OSC_HP) $f_{OSC}$ is used<br>10 <sub>B</sub> The PLL clock $f_{PLL}$ is used<br>11 <sub>B</sub> CLKIN1 as direct input clock $f_{CLKIN1}$ is used                                     |
| EMCLKSEL   | [4:3] | rw   | <b>Emergency Clock Select</b><br>This bit field defines the clock source that is used as system clock in case of an OSCWDT or VCOLCK emergency event.<br>00 <sub>B</sub> The Wake-up clock $f_{WU}$ is used<br>01 <sub>B</sub> The oscillator clock (OSC_HP) $f_{OSC}$ is used<br>10 <sub>B</sub> The PLL clock $f_{PLL}$ is used<br>11 <sub>B</sub> CLKIN1 as direct input clock $f_{CLKIN1}$ is used |
| EMCLKSELEN | 6     | rw   | <b>Emergency Clock Select Enable</b><br>Controls switching the system clock to an alternate source in case of an OSCWDT or VCOLCK event.<br>0 <sub>B</sub> The switching is disabled<br>1 <sub>B</sub> The switching is enabled                                                                                                                                                                        |

## System Control Unit (SCU)

| Field            | Bits        | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------|-------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>WUTCLKSEL</b> | [8:7]       | rw   | <b>WUT Clock Select</b><br>This bit field defines the clock source that is used as wake-up timer clock for operation.<br>00 <sub>B</sub> The Wake-up clock $f_{WU}$ is used<br>01 <sub>B</sub> The oscillator clock (OSC_HP) $f_{OSC}$ is used<br>10 <sub>B</sub> The PLL clock $f_{PLL}$ is used<br>11 <sub>B</sub> CLKIN1 as direct Input clock $f_{CLKIN1}$ is used                                                                                                                                                                                                                                               |
| <b>STMCLKSEL</b> | [11:9]      | rw   | <b>STM Clock Select</b><br>This bit field defines the clock source that is used as STM clock for operation.<br>000 <sub>B</sub> CLKIN2 as direct input clock $f_{CLKIN2}$ is used<br>001 <sub>B</sub> The oscillator clock (OSC_HP) $f_{OSC}$ is used<br>010 <sub>B</sub> The PLL clock $f_{PLL}$ is used<br>011 <sub>B</sub> CLKIN1 as direct Input clock $f_{CLKIN1}$ is used<br>100 <sub>B</sub> The Wake-up clock $f_{WU}$ is used<br>101 <sub>B</sub> Reserved, do not use this combination<br>110 <sub>B</sub> Reserved, do not use this combination<br>111 <sub>B</sub> Reserved, do not use this combination |
| <b>EMSOSC</b>    | 12          | rh   | <b>OSCWDT Emergency Event Source Status</b><br>0 <sub>B</sub> No OSCWDT emergency event occurred since EMSOSC has been cleared last<br>1 <sub>B</sub> An OSCWDT emergency event has occurred<br><i>Note: This bit is only set if EMCLKSELEN is set.</i>                                                                                                                                                                                                                                                                                                                                                              |
| <b>EMSVCO</b>    | 13          | rh   | <b>VCOLCK Emergency Event Source Status</b><br>0 <sub>B</sub> No VCOLCK emergency event occurred since EMSVCO has been cleared last<br>1 <sub>B</sub> A VCOLCK emergency event has occurred<br><i>Note: This bit is only set if EMCLKSELEN is set.</i>                                                                                                                                                                                                                                                                                                                                                               |
| <b>SELSTAT</b>   | 15          | rh   | <b>Clock Select Status</b><br>0 <sub>B</sub> The standard configuration from bit field CLKSEL is used currently<br>1 <sub>B</sub> The configuration from bit field EMCLKSEL is used currently                                                                                                                                                                                                                                                                                                                                                                                                                        |
| <b>0</b>         | 2, 5,<br>14 | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

## **System Control Unit (SCU)**

STATCLR0

## Status Clear 0 Register

ESFR (F0E0<sub>H</sub>/70<sub>H</sub>)

**Reset Value: 0000<sub>H</sub>**

| Field         | Bits               | Type | Description                                                                           |
|---------------|--------------------|------|---------------------------------------------------------------------------------------|
| <b>EMCOSC</b> | 12                 | w    | <b>EMSOSC Clear Trigger</b><br>$0_B$ No action<br>$1_B$ Bit SYSCON0.EMSOSC is cleared |
| <b>EMCVCO</b> | 13                 | w    | <b>EMSVCO Clear Trigger</b><br>$0_B$ No action<br>$1_B$ Bit SYSCON0.EMSVCO is cleared |
| <b>0</b>      | [11:0],<br>[15:14] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                               |

### **8.1.7.6 RTC Clock Control Register**

*Note: Only change register RTCCLKCON while the RTC is off.*

## RTCCLKCON

## RTC Clock Control Register

SFR (FF4E<sub>H</sub>/A7<sub>H</sub>)

**Reset Value: 0006<sub>H</sub>**

The diagram shows a register map with a horizontal axis representing memory addresses from 15 down to 0. The address 0 is highlighted with a red box. At address 0, there are two fields: 'RTC CM' and 'RTC CLKSEL'. The 'RTC CM' field is a read/write (RW) field, and the 'RTC CLKSEL' field is also a read/write (RW) field.

| Field            | Bits   | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------------|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>RTCCLKSEL</b> | [1:0]  | rw   | <p><b>RTC Clock Select</b></p> <p>This bit field defines the count clock source for the RTC.</p> <ul style="list-style-type: none"> <li>00<sub>B</sub> The PLL clock <math>f_{PLL}</math> is used</li> <li>01<sub>B</sub> The oscillator clock (OSC_HP) <math>f_{OSC}</math> is used</li> <li>10<sub>B</sub> The Wake-up clock signal <math>f_{WU}</math> is used</li> <li>11<sub>B</sub> CLKIN2 as direct input clock <math>f_{CLKIN2}</math> is used</li> </ul> |
| <b>RTCCM</b>     | 2      | rw   | <p><b>RTC Clocking Mode</b></p> <ul style="list-style-type: none"> <li>0<sub>B</sub> Asynchronous Mode:<br/>The RTC internally operates with <math>f_{RTC}</math>.<br/>No register access is possible.</li> <li>1<sub>B</sub> Synchronous Mode:<br/>The RTC internally operates with <math>f_{SYS}</math> clock.<br/>Registers can be read and written.</li> </ul>                                                                                                |
| <b>0</b>         | [15:3] | r    | <p><b>Reserved</b></p> <p>Read as 0; should be written with 0.</p>                                                                                                                                                                                                                                                                                                                                                                                                |

## System Control Unit (SCU)

### 8.1.7.7 External Clock Control Register

This register controls the setting of external clock for pin 2.8 and 7.1.

#### EXTCON

#### External Clock Control Register SFR (FF5E<sub>H</sub>/AF<sub>H</sub>)

**Reset Value: 0000<sub>H</sub>**

| 15                | 14                | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6                | 5                 | 4                | 3 | 2                 | 1 | 0                 |
|-------------------|-------------------|----|----|----|----|---|-------------------|---|------------------|-------------------|------------------|---|-------------------|---|-------------------|
| <b>FO<br/>EN</b>  | <b>FO<br/>SS</b>  |    |    |    |    |   | <b>FORV</b>       |   | <b>0</b>         | <b>FO<br/>TL</b>  | <b>0</b>         |   | <b>SEL</b>        |   | <b>EN</b>         |
| <small>rw</small> | <small>rw</small> |    |    |    |    |   | <small>rw</small> |   | <small>r</small> | <small>rh</small> | <small>r</small> |   | <small>rw</small> |   | <small>rw</small> |

| Field       | Bits   | Type              | Description                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------------|--------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>EN</b>   | 0      | <small>rw</small> | <b>External Clock Enable</b><br>$0_B$ No external clock signal is provided. The signal is tied to zero.<br>$1_B$ The configured external clock signal is provided as alternate output signal                                                                                                                                                                                                                                      |
| <b>SEL</b>  | [4:1]  | <small>rw</small> | <b>External Clock Select</b><br>Selects the clock signal to be routed to the EXTCLK pin:<br>$0000_B$ System clock $f_{SYS}$<br>$0001_B$ Programmable clock signal $f_{OUT}$<br>$0010_B$ PLL output clock $f_{PLL}$<br>$0011_B$ Oscillator clock $f_{OSC}$<br>$0100_B$ Wake-up clock $f_{WU}$<br>$0101_B$ Direct Input clock $f_{CLKIN1}$<br>$1000_B$ RTC count clock $f_{RTC}$<br>All other combination are reserved, do not use. |
| <b>FOTL</b> | 6      | <small>rh</small> | <b>Frequency Output Toggle Latch</b><br>Toggled upon each underflow of FOCNT.                                                                                                                                                                                                                                                                                                                                                     |
| <b>FORV</b> | [13:8] | <small>rw</small> | <b>Frequency Output Reload Value</b><br>Copied to FOCNT upon each underflow of FOCNT.                                                                                                                                                                                                                                                                                                                                             |
| <b>FOSS</b> | 14     | <small>rw</small> | <b>Frequency Output Signal Select</b><br>$0_B$ Output of the toggle latch<br>$1_B$ Output of the reload counter: duty cycle depends on FORV                                                                                                                                                                                                                                                                                       |

## System Control Unit (SCU)

| Field       | Bits | Type | Description                                                                                                                                                                                                              |
|-------------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>FOEN</b> | 15   | rw   | <b>Frequency Output Enable</b><br>0 <sub>B</sub> Frequency output generation stops when $f_{OUT}$ is/becomes low.<br>1 <sub>B</sub> FOCNT is running, $f_{OUT}$ is gated to pin.<br>First reload after 0 - 1 transition. |
| <b>0</b>    | 5, 7 | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                  |

## System Control Unit (SCU)

## 8.2 System Timer Function (STM)

The System Timer equips the device with a real time counter function

The STM function can operate on the clock sources described in [System Timer \(STM\) Clock Generation](#).

The STM consists of a 16-bit counter that is able to generate up to two interrupts. Driven by a clock source the counter can be used to count time based events and upon an interrupt trigger based on a time generated out of a clock different than the remaining of the system. A clock function can easily be implemented based on these interrupts in software.



Figure 8-16 STM Block Diagram

## 8.2.1 STM Registers

### 8.2.1.1 Register STMREL

Via this register, the reload value and therefore the period of the STM is defined.

**STMREL**

**STM Reload Register**

**ESFR (F1A8<sub>H</sub>/D4<sub>H</sub>)**

**Reset Value: 0000<sub>H</sub>**



| Field         | Bits    | Type | Description                                                                                                                                                                                                                                                     |
|---------------|---------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>RELLOW</b> | [9:0]   | rw   | <b>Reload Lower Value</b><br>The counter counts up and issues an interrupt trigger when bit 9 changes from 1 <sub>B</sub> to 0 <sub>B</sub> . Upon this trigger the counter is loaded with the reload value defined by this bit field.                          |
| <b>RELUP</b>  | [15:10] | rw   | <b>Reload Upper Value</b><br>The counter counts up and issues an interrupt trigger when bit 15 changes from 1 <sub>B</sub> to 0 <sub>B</sub> . Upon this trigger the counter is loaded with the reload value defined by this bit field and by bit field RELLOW. |

### 8.2.1.2 Register STMCON

This register holds the status and control bits for the STM.

#### STMCON

##### STM Control Register

 ESFR (F1AA<sub>H</sub>/D5<sub>H</sub>)

 Reset Value: 0000<sub>H</sub>


| Field  | Bits   | Type | Description                                                                                                                                                                |
|--------|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RUN    | 0      | rw   | <b>Run Control</b><br>$0_B$ STM is stopped<br>$1_B$ STM is operating<br>By setting this bit the STM is started and the reload value STMREL.REL is loaded into the counter. |
| CLKDIV | [4:1]  | rw   | <b>Clock Divider for the STM Clock</b><br>This bit field defines the divider factor of the STM clock input. The selected input clock is divided by $2^{<\text{CLKDIV}>}$ . |
| 0      | [15:5] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                    |

## System Control Unit (SCU)

### 8.3 Wake-up Timer (WUT)

The Wake-up Timer provides an additional resource to trigger system functions after a specific period of time.

The Wake-up Timer function can operate on the clock sources described in [Wake-up Timer \(WUT\) Clock Generation](#).

The wake-up timer clock  $f_{WUT}$  drives a simple counter. All functions are controlled by register WUCR.



**Figure 8-17 Wake-up Timer Logic**

#### 8.3.1 Wake-up Timer Operation

The Wake-up Timer start and stop is controlled by the Run Control logic. The timer can be started in the following way:

- bit WUCR.RUN is set

When the timer is started the prescaler is reset and the counter starts to count down.

The wake-up interval counter is clocked with  $f_{WUT}$  and counts down until it reaches zero. It then generates a wake-up trigger and sets bit WUCR.WUTRG.

The timer is stopped in the following ways:

- bit WUCR.RUN is cleared
- bit WUCR.ASP is set AND a wake-up trigger is generated

If the counter is not stopped by its zero trigger it continues counting down from WUTREL.

## System Control Unit (SCU)

### Determination of Wake-up Period

The actual frequency of the trimmed current controlled wake-up clock (OSC\_WU) can be measured prior to entering power-save mode in order to adjust the number of clock cycles to be counted (value written to the counter) and so to define the time until wake-up. The period of the OSC\_WU can be measured by evaluating the (synchronized) trigger that can generate interrupt requests or can be monitored with bit WUCR.TTSTAT.

As using an interrupt together with software contain some uncertainty there is a second way to determine the wake-up period. The wake-up triggers generated by the WUT are forwarded to the CCU60 and can there be evaluated compared to the accurate system clock.

## 8.3.2 WUT Registers

### 8.3.2.1 Register WUTREL

This register configures the reload value of the counter.

**WUTREL**

**Wake-up Timer Reload Register**



| Field         | Bits   | Type | Description                                                                                                                          |
|---------------|--------|------|--------------------------------------------------------------------------------------------------------------------------------------|
| <b>RELVAL</b> | [15:0] | rw   | <b>Wake-up Timer Reload Value</b><br>The WUT counter is reloaded with this value and starts to count down when the timer is started. |

## System Control Unit (SCU)

## 8.3.2.2 Register WUCR

This register the status and control bits for the WUT.

**WUCR**
**Wake-up Control Register**
**ESFR ( $F1B0_H/D8_H$ )**
**Reset Value:  $0000_H$** 

| 15        | 14         | 13     | 12 | 11 | 10  | 9   | 8   | 7          | 6 | 5          | 4          | 3 | 2          | 1 | 0 |
|-----------|------------|--------|----|----|-----|-----|-----|------------|---|------------|------------|---|------------|---|---|
| WU<br>TRG | TTS<br>TAT | CLKDIV |    |    | ASP | AON | RUN | CLR<br>TRG | 0 | ASP<br>CON | AON<br>CON |   | RUN<br>CON |   |   |
| rh        | rh         | rw     |    | rh | rh  | rh  | w   | r          | w | w          | w          | w | w          | w |   |

| Field  | Bits  | Type | Description                                                                                                                                                                                                                          |
|--------|-------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RUNCON | [1:0] | w    | <b>Control Field for RUN</b><br>$00_B$ No action<br>$01_B$ Set bit RUN<br>$10_B$ Clear bit RUN<br>$11_B$ Reserved, do not use this combination                                                                                       |
| AONCON | [3:2] | w    | <b>Control Field for AON</b><br>$00_B$ No action<br>$01_B$ Reserved, do not use this combination<br>$10_B$ Clear bit AON<br>$11_B$ Reserved, do not use this combination                                                             |
| ASPCON | [5:4] | w    | <b>Control Field for ASP</b><br>$00_B$ No action<br>$01_B$ Set bit ASP<br>$10_B$ Clear bit ASP<br>$11_B$ Reserved, do not use this combination                                                                                       |
| CLRTRG | 7     | w    | <b>Clear Bit WUTRG</b><br>$0_B$ No action<br>$1_B$ Clear bit WUTRG                                                                                                                                                                   |
| RUN    | 8     | rh   | <b>Run Indicator</b><br>$0_B$ Wake-up counter is stopped<br>$1_B$ Wake-up counter is counting down<br><i>Note: Clearing this bit via a write action to bit field RUNCON stops the WUT after four cycles of <math>f_{WUT}</math>.</i> |

## System Control Unit (SCU)

| Field  | Bits    | Type | Description                                                                                                                                                                                                                                                                                            |
|--------|---------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AON    | 9       | rh   | <b>Auto-Start Indicator</b><br>$0_B$ Wake-up counter is started by software only<br>$1_B$ Reserved, do not use this combination<br><i>Note: This bit is cleared by writing <math>01_B</math> to bit field AONCON.</i>                                                                                  |
| ASP    | 10      | rh   | <b>Auto-Stop Indicator</b><br>$0_B$ Wake-up counter runs continuously<br>$1_B$ Wake-up counter stops after generating a trigger when reaching zero                                                                                                                                                     |
| CLKDIV | [13:11] | rw   | <b>Clock Divider for the WUT Clock</b><br>This bit field defines the divider factor of the WUT clock input. The selected input clock is divided by $2^{<\text{CLKDIV}>}$ .                                                                                                                             |
| TTSTAT | 14      | rh   | <b>Trim Trigger Status</b><br>$0_B$ No trim trigger event is active. No trim interrupt trigger is generated.<br>$1_B$ A trim trigger event is active. A trim interrupt trigger is generated.<br><i>Note: This bit is not valid if <math>f_{WUT} = f_{WU}</math> is configured by SYSCON0.WUTCLKSEL</i> |
| WUTRG  | 15      | rh   | <b>WUT Trigger Indicator</b><br>$0_B$ No trigger event has occurred since WUTRG has been cleared last. No interrupt trigger is generated.<br>$1_B$ A wake-up trigger event has occurred. A wake-up interrupt trigger is generated.                                                                     |
| 0      | 6       | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                |

*Note: The bits in the upper byte of register WUCR indicate the current status of the wake-up counter logic. They are not influenced by a write access, but are controlled by their associated control fields (lower byte) or by hardware.*

*The control bit(field)s in the lower byte of register WUCR determine the state of the status bits (upper byte) of the wake-up counter logic. Setting bits by software triggers the associated action, writing 0 has no effect.*

## 8.4 Reset Operation

All resets are generated by the Reset Control Block. It handles the control of the reset triggers as well as the length of a reset and the reset timing. A reset leads the system, or a part of the system depending on the reset, to a initialization into a defined state.

### 8.4.1 Reset Architecture

The XC27x5X contains a very sophisticated reset architecture to offer the greatest amount of flexibility for the support of different applications. The reset architecture supports the different power domains.

Different reset types for the complete system are supported.

#### 8.4.1.1 Device Reset Hierarchy

The device reset hierarchy is divided according to the power domains (see [Chapter 8.6](#)) into following linked levels:

Level 1: I/O domain (power domain DMP\_B)

Level 2: System power domain DMP\_M

Level 3: System power domain DMP\_1

If a power domain (level) is deactivated all resets of the deactivated level and all resets of all lower power domains are asserted.

#### 8.4.1.2 Reset Types

The following summary shows the different reset types.

### Power Reset

- Power-on Reset  
This reset leads to a defined state of the complete system. This reset should only be requested on a real power-on event and not by any non power related event.
- Power Reset for DMP\_M and DMP\_1 power domains  
This reset regains data consistency upon a power fail in the DMP\_M or DMP\_1 power domains.

### Functional / User Reset

- Debug Reset  
This reset leads to a defined state of the complete debug system.
- Internal Application Reset  
This reset leads to a defined state of the complete application system with the following parts: all peripherals (except the RTC), the CPU and partially the SCU and the flash memory.

## System Control Unit (SCU)

- Application Reset

This reset leads to a defined state of the complete application system with the following parts: all peripherals (except the Ports and the RTC), the CPU and partially the SCU and the flash memory.

After a reset has been executed, the Reset Status registers RSTSTATx indicate the latest reset that has occurred.

To identify the type and the trigger of the latest reset registers RSTSTATx and **SWDCON1** may be evaluated according to [Table 8-1](#). The latest reset that has occurred is always the reset of the highest type. If two reset triggers of the same type are indicated, this means that the two triggers have been active at the same time. If two or more reset triggers of a different type are reported, always the reset of the highest type is the latest one.

**Table 8-1 Identification of a Reset**

| Type of Reset<br>(in hierarchical order, highest on top) | Identification                                                                                                                                                                 |
|----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Power-on Reset                                           | SWDCON1.PON = $1_B$<br>RSTSTAT1.STM = $11_B$<br>RSTSTAT1.ST1 = $11_B$<br>Further action: clear PON bit to be able to identify a Power Reset for DMP_M and DMP_1 power domains. |
| Power Reset for DMP_M and DMP_1 power domains            | SWDCON1.PON = $0_B$ (unchanged after clearing)<br>RSTSTAT1.STM = $11_B$<br>RSTSTAT1.ST1 = $11_B$                                                                               |
| Internal Application Reset                               | RSTSTAT1.ST1 = $00_B$<br>any bit field y in RSTSTATx.y = $10_B$                                                                                                                |
| Application Reset                                        | RSTSTAT1.ST1 = $00_B$<br>any bit field y in RSTSTATx.y = $11_B$ (except RSTSAT1.ST1 and RSTSTAT1.STM)                                                                          |

The algorithm depicted in [Figure 8-18](#) shows a sequence to detect the type of the reset comprising the conditions in [Table 8-1](#). Further information can be found in the Programmer's Guide.



**Figure 8-18** Algorithm for the Detection of the Type of a Reset

## 8.4.2 General Reset Operation

A reset is generated if an enabled reset request trigger is asserted. Most reset request triggers can be configured for the reset type it should initiate. No action (disabled) is one possible configuration and can be selected for a reset request trigger by setting the respective bit field in a Reset Configuration Register to  $00_B$ . The debug reset can only be requested by dedicated reset request triggers and can not be selected via a Reset Configuration Register. For more information see also registers **RSTCON0** and **RSTCON1**.

The duration of a reset is defined by two independent counters. One counter for the System and Application Reset types and one separate counter for the debug reset. A separate counter for the debug reset was implemented to allow a non-intrusive adaptation of the reset length to the debugger needs without modification of the application setting.

### 8.4.2.1 Reset Counters (RSTCNTA and RSTCNDT)

RSTCNTA is the reset counter that controls the reset length for all application relevant resets (Internal Application Reset, and Application Reset). RSTCNDT is the reset counter that controls the reset length for the debug reset.

The reset counters control the length of the internal resets. This can be used to configure the duration of a reset output via the ESRx pins, so this matches with the reset input requirements of external blocks connected to these signals.

A reset counter RSTCNT is an 8-bit counter counting down from the reload value defined by **RSTCNTCON.RELx** ( $x = A$  or  $D$ ). The counter is started by the reset control block as soon as a reset request trigger condition becomes active (for more information see **Table 8-2** and **Table 8-3**). Whether the counter has to be started or not depends on the reset request trigger and whether the counter is already active or not. In case of that the counter is inactive, not counting down, it is always started. While the counter is already active it depends on the reset type of the new reset request trigger that was asserted anew if the counter is restarted or not. This behavior is summarized in **Table 8-2** and **Table 8-3**.

**Table 8-2**    **Restart of RSTCNTA**

| Reset Active               | New Reset Trigger          |             |                            |                   |
|----------------------------|----------------------------|-------------|----------------------------|-------------------|
|                            | Power-On                   | Debug Reset | Internal Application Reset | Application Reset |
| Internal Application Reset | Restart with default delay | No Change   | No Change                  | No Change         |
| Application Reset          | Restart with default delay | No Change   | Restart with defined delay | No Change         |

**Table 8-3**    **Restart of RSTCNDT**

| Reset Active | New Reset Trigger          |             |                            |                   |
|--------------|----------------------------|-------------|----------------------------|-------------------|
|              | Power-On                   | Debug Reset | Internal Application Reset | Application Reset |
| Debug Reset  | Restart with default delay | No Change   | No Change                  | No Change         |

The reset counters RSTCNTx ensure a configurable minimum duration of a generated reset. If a reset request trigger remains asserted after the respective counter has counted down, the counter is not started again, instead the reset control block keeps the reset asserted until the reset request trigger is deasserted.

#### 8.4.2.2 De-assertion of a Reset

The reset of a dedicated type is de-asserted when all of the following conditions are fulfilled:

- The reset counter has been expired (reached zero).
- No reset request trigger that is configured to generate a reset of the dedicated type (or higher) is currently asserted.

#### Example1

Reset request trigger A is asserted and leads to an Application Reset. If the reset request trigger is de-asserted before RSTCNTA reached zero the Application Reset is de-asserted when RSTCNTA reaches zero. If the reset request trigger is de-asserted after RSTCNTA reached zero the Application Reset is de-asserted when the reset request trigger is de-asserted.

## Example2

Reset request trigger A is asserted and leads to an Application Reset. Reset request trigger A is de-asserted before RSTCNTA reached zero. Reset request trigger B is asserted after reset request trigger A but before RSTCNTA reaches zero. Reset request trigger B is also configured to result in a Application Reset. If the reset request trigger B is de-asserted before RSTCNTA reached zero the Application Reset is de-asserted when RSTCNTA reaches zero. If the reset request trigger B is de-asserted after RSTCNTA reached zero the Application Reset is de-asserted when the reset request trigger B is de-asserted.

### 8.4.3 Debug Reset Assertion

Unlike the other reset types a Debug Reset can only be asserted if the following two conditions are valid:

- A reset request trigger is asserted that request a debug reset
- An Application Reset is already active in the system

### 8.4.4 Coupling of Reset Types

The different reset types are coupled for a better usage:

- The assertion of a Power-on Reset automatically asserts also the following reset types:
  - Debug Reset
  - Internal Application Reset
  - Application Reset
- The assertion of an Internal Application Reset automatically asserts also the following reset type:
  - Application Reset

### 8.4.5 Reset Request Trigger Sources

The following overview summarizes the different reset request trigger sources within the system.

#### **Power-On Reset Pin PORST**

A Power-on Reset is requests asynchronously, by driving the PORST pin low.

#### **Supply Watchdog (SWD)**

If the power supply for I/O domain is below the value required for proper functionality, a non-synchronized reset request trigger is generated if the SWD reset generation is enabled. This ensures a reproducible behavior in the case of power-fail. This can also be used to restart the system without the usage of the PORST pin. As long as the I/O power domain does not get the required voltage level the system is held in the reset.

#### **Core Power Validation (PVC\_M and PVC\_1)**

If the core power supply is below the value required for proper functionality of the main power domain (PVC\_M), a reset request trigger can be forwarded to the system. The generation of a Power-on Reset is configured by bit PVC<sub>M</sub>CON0.L1RSTEN = 1<sub>B</sub>. If the bit PVC<sub>M</sub>CON0.L1RSTEN = 1<sub>B</sub> a request trigger is asserted for PVC\_M1 upon a level check match. If the bit PVC<sub>M</sub>CON0.L2RSTEN = 1<sub>B</sub> a request trigger is asserted for PVC\_M2 upon a level check match.

If the core power supply is below the value required for proper functionality of the application power domain (PVC\_1), a reset request trigger can be forwarded to the system. The generation of a Power-on Reset (Application Power Domain only) is configured by bit PVC<sub>1</sub>CON0.L1RSTEN = 1<sub>B</sub>. If bit PVC<sub>1</sub>CON0.L1RSTEN = 1<sub>B</sub> a request trigger is asserted for PVC\_11 upon a level check match. If the bit PVC<sub>1</sub>CON0.L2RSTEN = 1<sub>B</sub> a request trigger is asserted for PVC\_12 upon a level check match.

For more information about the Power Validation Circuit see [Chapter 8.6.2](#).

#### **ESRx**

An ESRx reset request trigger leads to a configurable reset. The type of reset can be configured via [RSTCON1.ESRx](#).

The pins ESRx can serve as an external reset input as well as a reset output (open drain) for Internal Application and Application Resets. Furthermore, several GPIO pad triggers, that can be enabled additionally via register ESREXCONx (x = 1, 2), interfere with the ESR pin function. GPIO and ESRx pin triggers can be enabled/disabled individually and are combined for the reset trigger generation.

## System Control Unit (SCU)

If pin ESRx is enabled as reset output and the input level is low while the output stage is disabled (indicating that it is still driven low externally), the reset circuitry holds the chip in reset until a high level is detected on ESRx. Minimum value for RSTCNTCON.RELA must be the reset value.

*Note: The reset output is only driven low for the duration the reset counter RSTCNTA is active. During a possible reset extension the reset output is no longer driven.*

### Software

A software reset request trigger leads to a configurable reset. The type of reset can be configured via **RSTCON0.SW**.

### Watchdog Timer

A WDT reset request trigger leads to a configurable reset. The type of reset can be configured via **RSTCON1.WDT**. A WDT reset is requested on a WDT overflow event. For more information see [Chapter 8.12](#).

### CPU

A CPU reset request trigger leads to a configurable reset. The type of reset can be configured via **RSTCON0.CPU**. A CPU reset is requested when instruction SRST is executed.

### Memory Parity

A MP reset request trigger leads to a configurable reset. The type of reset can be configured via **RSTCON1.MP**. For more information see [Chapter 8.14.2](#).

### OCDS Block

The OCDS block has several options to request different reset types:

1. A Debug Reset either via the OCDS reset function or via bit CBS\_OJCONF.RSTCL1 AND CBS\_OJCONF.RSTCL3
2. An Internal Application Reset via bit CBS\_OJCONF.RSTCL2
3. An Application Reset via bit CBS\_OJCONF.RSTCL3

#### 8.4.5.1 Reset Sources Overview

The connection of the reset sources and the activated reset types are shown in [Table 8-4](#).

**Table 8-4 Effects of Reset Types for Reset Activation**

| Reset Request Trigger    | Application Reset | Internal Application Reset | Debug Reset             |
|--------------------------|-------------------|----------------------------|-------------------------|
| <b>PORST</b>             | Activated         | Activated                  | Activated               |
| <b>SWD</b>               | Activated         | Activated                  | Activated               |
| <b>PVC_M1</b>            | Activated         | Activated                  | Activated               |
| <b>PVC_M2</b>            | Activated         | Activated                  | Activated               |
| <b>PVC_11</b>            | Activated         | Activated                  | Activated               |
| <b>PVC_12</b>            | Activated         | Activated                  | Activated               |
| <b>ESR0</b>              | Configurable      | Configurable               | Not Activated           |
| <b>ESR1</b>              | Configurable      | Configurable               | Not Activated           |
| <b>ESR2</b>              | Configurable      | Configurable               | Not Activated           |
| <b>WDT</b>               | Configurable      | Configurable               | Not Activated           |
| <b>SW</b>                | Configurable      | Configurable               | Not Activated           |
| <b>CPU</b>               | Configurable      | Configurable               | Not Activated           |
| <b>MP</b>                | Configurable      | Configurable               | Not Activated           |
| <b>OCDS Reset</b>        | Not Activated     | Not Activated              | Activated <sup>1)</sup> |
| <b>CBS_OJCONF.RSTCL1</b> | Not Activated     | Not Activated              | Activated <sup>1)</sup> |
| <b>CBS_OJCONF.RSTCL2</b> | Activated         | Activated                  | Not Activated           |
| <b>CBS_OJCONF.RSTCL3</b> | Activated         | Not Activated              | Not Activated           |

<sup>1)</sup> Only if an Application Reset is active or is requested in parallel.

#### 8.4.6 Module Reset Behavior

**Table 8-5** lists how the various functions of the XC27x5X are affected through a reset depending on the reset type. A “X” means that this block has at least some register/bits that are affected by this reset type.

## System Control Unit (SCU)

**Table 8-5 Effect of Reset on Device Functions**

| Module / Function                 |       | Application Reset      | Internal Application Reset | Debug Reset            |
|-----------------------------------|-------|------------------------|----------------------------|------------------------|
| CPU Core                          |       | X                      | X                          | X                      |
| Peripherals (except SCU and RTC)  |       | X                      | X                          | X                      |
| SCU                               |       | X                      | Not affected               | Not affected           |
| RTC                               |       | Not affected           | Not affected               | X                      |
| On-chip Static RAMs <sup>1)</sup> | DPRAM | Not affected, reliable | Not affected, reliable     | Not affected, reliable |
|                                   | PSRAM | Not affected, reliable | Not affected, reliable     | Not affected, reliable |
|                                   | DSRAM | Not affected, reliable | Not affected, reliable     | Not affected, reliable |
| Flash Memory                      |       | X <sup>2)</sup>        | X <sup>2)</sup>            | Not affected, reliable |
| JTAG Interface                    |       | Not affected           | Not affected               | Not affected           |
| OCDS                              |       | Not affected           | Not affected               | X                      |
| Oscillator, PLL                   |       | Not affected           | Not affected               | Not affected           |
| Port Pins                         |       | Not affected           | X                          | Not affected           |
| Pins ESRx                         |       | Not affected           | X                          | Not affected           |

<sup>1)</sup> Reliable here means that also the redundancy is not affected by the reset.

<sup>2)</sup> Parts of the flash memory block are only reset by a Power-on Reset. For more detail see the flash chapter.

## 8.4.7 Reset Controller Registers

### 8.4.7.1 Status Registers

After a reset has been executed, the Reset Status registers provide information on the type of the last reset. The reset status registers are updated upon each reset.

#### RSTSTAT0

| Reset Status 0 Register |     |    |    |    |    |   |   |   |   | ESFR (F0B2 <sub>H</sub> /59 <sub>H</sub> ) |   | Reset Value: 0000 <sub>H</sub> |   |   |   |   |  |  |
|-------------------------|-----|----|----|----|----|---|---|---|---|--------------------------------------------|---|--------------------------------|---|---|---|---|--|--|
| 15                      | 14  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5                                          | 4 | 3                              | 2 | 1 | 0 |   |  |  |
|                         |     |    |    |    |    |   |   |   |   |                                            |   |                                |   |   |   | 0 |  |  |
| SW                      | CPU |    |    |    |    |   |   |   |   |                                            |   |                                |   |   |   |   |  |  |
| rh                      | rh  |    |    |    |    |   |   |   |   |                                            |   |                                |   |   |   | r |  |  |

| Field | Bits    | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|---------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CPU   | [13:12] | rh   | <b>CPU Reset Type Status</b><br>00 <sub>B</sub> The CPU reset trigger was not relevant for the last reset<br>01 <sub>B</sub> Reserved<br>10 <sub>B</sub> The CPU reset trigger was relevant for the last reset. Internal Application and Application Resets were generated.<br>11 <sub>B</sub> The CPU reset trigger was relevant for the last reset. Application Reset was generated.                     |
| SW    | [15:14] | rh   | <b>Software Reset Type Status</b><br>00 <sub>B</sub> The Software reset trigger was not relevant for the last reset<br>01 <sub>B</sub> Reserved<br>10 <sub>B</sub> The Software reset trigger was relevant for the last reset. Internal Application and Application Resets were generated.<br>11 <sub>B</sub> The Software reset trigger was relevant for the last reset. Application Reset was generated. |
| 0     | [11:0]  | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                                                                                                    |

## System Control Unit (SCU)

**RSTSTAT1**
**Reset Status 1 Register**
**ESFR (F0B4<sub>H</sub>/5A<sub>H</sub>)**
**Reset Value: F000<sub>H</sub>**

|            |            |    |          |    |           |   |            |   |             |   |             |   |             |   |    |
|------------|------------|----|----------|----|-----------|---|------------|---|-------------|---|-------------|---|-------------|---|----|
| 15         | 14         | 13 | 12       | 11 | 10        | 9 | 8          | 7 | 6           | 5 | 4           | 3 | 2           | 1 | 0  |
| <b>ST1</b> | <b>STM</b> |    | <b>0</b> |    | <b>MP</b> |   | <b>WDT</b> |   | <b>ESR2</b> |   | <b>ESR1</b> |   | <b>ESR0</b> |   |    |
| rh         | rh         |    | r        |    | rh        |   | rh         |   | rh          |   | rh          |   | rh          |   | rh |

| Field       | Bits  | Type | Description                                                                                                                                                                                                                                                                                                                                        |
|-------------|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ESR0</b> | [1:0] | rh   | <b>ESR0 Reset Status</b><br>$00_B$ The ESR0 reset trigger was not relevant for the last reset<br>$01_B$ Reserved<br>$10_B$ The ESR0 reset trigger was relevant for the last reset. Internal Application, and Application Resets were generated.<br>$11_B$ The ESR0 reset trigger was relevant for the last reset. Application Reset was generated. |
| <b>ESR1</b> | [3:2] | rh   | <b>ESR1 Reset Status</b><br>$00_B$ The ESR1 reset trigger was not relevant for the last reset<br>$01_B$ Reserved<br>$10_B$ The ESR1 reset trigger was relevant for the last reset. Internal Application, and Application Resets were generated.<br>$11_B$ The ESR1 reset trigger was relevant for the last reset. Application Reset was generated. |
| <b>ESR2</b> | [5:4] | rh   | <b>ESR2 Reset Status</b><br>$00_B$ The ESR2 reset trigger was not relevant for the last reset<br>$01_B$ Reserved<br>$10_B$ The ESR2 reset trigger was relevant for the last reset. Internal Application, and Application Resets were generated.<br>$11_B$ The ESR2 reset trigger was relevant for the last reset. Application Reset was generated. |

**System Control Unit (SCU)**

| <b>Field</b> | <b>Bits</b> | <b>Type</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------------|-------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>WDT</b>   | [7:6]       | rh          | <p><b>WDT Reset Status</b></p> <p>00<sub>B</sub> The WDT reset trigger was not relevant for the last reset</p> <p>01<sub>B</sub> Reserved</p> <p>10<sub>B</sub> The WDT reset trigger was relevant for the last reset. Internal Application, and Application Resets were generated.</p> <p>11<sub>B</sub> The WDT reset trigger was relevant for the last reset. Application Reset was generated.</p>                                                         |
| <b>MP</b>    | [9:8]       | rh          | <p><b>MP Reset Status</b></p> <p>00<sub>B</sub> The MP reset trigger was not relevant for the last reset</p> <p>01<sub>B</sub> Reserved</p> <p>10<sub>B</sub> The MP reset trigger was relevant for the last reset. Internal Application, and Application Resets were generated.</p> <p>11<sub>B</sub> The MP reset trigger was relevant for the last reset. Application Reset was generated.</p>                                                             |
| <b>STM</b>   | [13:12]     | rh          | <p><b>Power-on for DMP_M Reset Status</b></p> <p>00<sub>B</sub> The power-on reset for DMP_M reset trigger was not relevant for the last reset</p> <p>01<sub>B</sub> The power-on reset for DMP_M reset trigger was not relevant for the last reset</p> <p>10<sub>B</sub> The power-on reset for DMP_M reset trigger was not relevant for the last reset</p> <p>11<sub>B</sub> The power-on reset for DMP_M reset trigger was relevant for the last reset</p> |
| <b>ST1</b>   | [15:14]     | rh          | <p><b>Power-on for DMP_1 Reset Status</b></p> <p>00<sub>B</sub> The power-on reset for DMP_1 reset trigger was not relevant for the last reset</p> <p>01<sub>B</sub> The power-on reset for DMP_1 reset trigger was not relevant for the last reset</p> <p>10<sub>B</sub> The power-on reset for DMP_1 reset trigger was not relevant for the last reset</p> <p>11<sub>B</sub> The power-on reset for DMP_1 reset trigger was relevant for the last reset</p> |
| <b>0</b>     | [11:10]     | r           | <p><b>Reserved</b></p> <p>Read as 0; should be written with 0.</p>                                                                                                                                                                                                                                                                                                                                                                                            |

## System Control Unit (SCU)

**RSTSTAT2**
**Reset Status 2 Register**
**ESFR (F0B6<sub>H</sub>/5B<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**

| 15 | 14 | 13 | 12 | 11      | 10      | 9       | 8 | 7  | 6  | 5 | 4 | 3  | 2 | 1 | 0 |
|----|----|----|----|---------|---------|---------|---|----|----|---|---|----|---|---|---|
| 0  |    |    |    | OJCONF3 | OJCONF2 | OJCONF1 | 0 |    | DB |   |   |    |   |   |   |
| r  |    |    |    | rh      | rh      | rh      |   | rh |    | r |   | rh |   |   |   |

| Field          | Bits  | Type | Description                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>DB</b>      | [1:0] | rh   | <b>Debug Reset Status</b><br>$00_B$ The DB reset trigger was not relevant for the last reset<br>$01_B$ The DB reset trigger was not relevant for the last reset<br>$10_B$ The DB reset trigger was not relevant for the last reset<br>$11_B$ The DB reset trigger was relevant for the last reset                                                                                     |
| <b>OJCONF1</b> | [5:4] | rh   | <b>OJCONF1 Reset Status</b><br>$00_B$ The OJCONF1 reset trigger was not relevant for the last reset<br>$01_B$ The OJCONF1 reset trigger was not relevant for the last reset<br>$10_B$ The OJCONF1 reset trigger was not relevant for the last reset<br>$11_B$ The OJCONF1 reset trigger was relevant for the last reset. Debug Reset was generated.                                   |
| <b>OJCONF2</b> | [7:6] | rh   | <b>OJCONF2 Reset Status</b><br>$00_B$ The OJCONF2 reset trigger was not relevant for the last reset<br>$01_B$ The OJCONF2 reset trigger was not relevant for the last reset<br>$10_B$ The OJCONF2 reset trigger was relevant for the last reset. Internal Application, and Application Resets were generated.<br>$11_B$ The OJCONF2 reset trigger was not relevant for the last reset |

## System Control Unit (SCU)

| Field   | Bits              | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------|-------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OJCONF3 | [9:8]             | rw   | <b>OJCONF3 Reset Status</b> <p> <math>00_B</math> The OJCONF3 reset trigger was not relevant for the last reset<br/> <math>01_B</math> The OJCONF3 reset trigger was not relevant for the last reset<br/> <math>10_B</math> The OJCONF3 reset trigger was not relevant for the last reset<br/> <math>11_B</math> The OJCONF3 reset trigger was relevant for the last reset. Application Reset was generated.         </p> |
| 0       | [3:2],<br>[15:10] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                                                                                                                   |

### 8.4.7.2 Configuration Registers

These registers allow the behavioral configuration for the various reset trigger sources.

#### RSTCON0

##### Reset Configuration 0 Register ESFR ( $F0B8_H/5C_H$ )

**Reset Value:  $0000_H$**



| Field | Bits    | Type | Description                                                                                                                                                                                                                                                                                                                                                           |
|-------|---------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CPU   | [13:12] | rw   | <b>CPU Reset Type Selection</b><br>This bit field defines which reset types are generated by a CPU reset request trigger.<br>00 <sub>B</sub> No reset is generated<br>01 <sub>B</sub> Reserved, do not use this combination<br>10 <sub>B</sub> Internal Application, and Application Resets are generated<br>11 <sub>B</sub> Application Reset is generated           |
| SW    | [15:14] | rw   | <b>Software Reset Type Selection</b><br>This bit field defines which reset types are generated by a software reset request trigger.<br>00 <sub>B</sub> No reset is generated<br>01 <sub>B</sub> Reserved, do not use this combination<br>10 <sub>B</sub> Internal Application, and Application Resets are generated<br>11 <sub>B</sub> Application Reset is generated |
| 0     | [11:0]  | rw   | <b>Reserved</b><br>Must be written with reset value 0.                                                                                                                                                                                                                                                                                                                |

## System Control Unit (SCU)

**RSTCON1**
**Reset Configuration 1 Register ESFR (F0BA<sub>H</sub>/5D<sub>H</sub>)**
**Reset Value: 0002<sub>H</sub>**

|    |    |    |    |     |    |      |   |      |   |      |   |    |   |    |   |
|----|----|----|----|-----|----|------|---|------|---|------|---|----|---|----|---|
| 15 | 14 | 13 | 12 | 11  | 10 | 9    | 8 | 7    | 6 | 5    | 4 | 3  | 2 | 1  | 0 |
| 0  |    | MP |    | WDT |    | ESR2 |   | ESR1 |   | ESR0 |   |    |   |    |   |
|    |    | rw |    |     | rw |      |   | rw   |   | rw   |   | rw |   | rw |   |

| Field       | Bits  | Type | Description                                                                                                                                                                                                                                                                                                                                                   |
|-------------|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ESR0</b> | [1:0] | rw   | <b>ESR0 Reset Type Selection</b><br>This bit field defines which reset types are generated by a ESR0 reset request trigger.<br>00 <sub>B</sub> No reset is generated<br>01 <sub>B</sub> Reserved, do not use this combination<br>10 <sub>B</sub> Internal Application, and Application Resets are generated<br>11 <sub>B</sub> Application Reset is generated |
| <b>ESR1</b> | [3:2] | rw   | <b>ESR1 Reset Type Selection</b><br>This bit field defines which reset types are generated by a ESR1 reset request trigger.<br>00 <sub>B</sub> No reset is generated<br>01 <sub>B</sub> Reserved, do not use this combination<br>10 <sub>B</sub> Internal Application, and Application Resets are generated<br>11 <sub>B</sub> Application Reset is generated |
| <b>ESR2</b> | [5:4] | rw   | <b>ESR2 Reset Type Selection</b><br>This bit field defines which reset types are generated by a ESR2 reset request trigger.<br>00 <sub>B</sub> No reset is generated<br>01 <sub>B</sub> Reserved, do not use this combination<br>10 <sub>B</sub> Internal Application, and Application Resets are generated<br>11 <sub>B</sub> Application Reset is generated |

## System Control Unit (SCU)

| Field | Bits    | Type | Description                                                                                                                                                                                                                                                                                                                                                 |
|-------|---------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WDT   | [7:6]   | rw   | <b>WDT Reset Type Selection</b><br>This bit field defines which reset types are generated by a WDT reset request trigger.<br>00 <sub>B</sub> No reset is generated<br>01 <sub>B</sub> Reserved, do not use this combination<br>10 <sub>B</sub> Internal Application, and Application Resets are generated<br>11 <sub>B</sub> Application Reset is generated |
| MP    | [9:8]   | rw   | <b>MP Reset Type Selection</b><br>This bit field defines which reset types are generated by a MP reset request trigger.<br>00 <sub>B</sub> No reset is generated<br>01 <sub>B</sub> Reserved, do not use this combination<br>10 <sub>B</sub> Internal Application, and Application Resets are generated<br>11 <sub>B</sub> Application Reset is generated   |
| 0     | [15:10] | rw   | <b>Reserved</b><br>Should be written with 0.                                                                                                                                                                                                                                                                                                                |

## System Control Unit (SCU)

**RSTCNTCON**
**Reset Counter Control RegisterESFR (F1B2<sub>H</sub>/D9<sub>H</sub>)**

 Reset Value: 0A0A<sub>H</sub>


| Field | Bits   | Type | Description                                                                                                                                                                                                                                                                                                                             |
|-------|--------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RELA  | [7:0]  | rW   | <b>Application Reset Counter Reload Value</b><br>This bit field defines the reload value of RSTCNTA.<br>This value is always used when counter RSTCNTA is started.<br>This counter value is used for Internal Application, and Application Resets.<br>In case of an ESRx reset the counter value must be not less than the reset value. |
| RELD  | [15:8] | rW   | <b>Debug Reset Counter Reload Value</b><br>This bit field defines the reload value of RSTCNDT.<br>This value is always used when counter RSTCNDT is started.<br>This counter value is used for the Debug Reset.<br>In case of an ESRx reset the counter value must be not less than the reset value.                                    |

## System Control Unit (SCU)

**Software Reset Control Register**

This register controls the software reset operation.

**SWRSTCON**
**Software Reset Control RegisterESFR (F0AE<sub>H</sub>/57<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**

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

| Field           | Bits   | Type | Description                                                                                                                                                                                                                                                    |
|-----------------|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>SWBOOT</b>   | 0      | rw   | <b>Software Boot Configuration Selection</b><br>$0_B$ Bit field STSTAT.HWCFG is not updated with the content of SWCFG upon an Application Reset<br>$1_B$ Bit field STSTAT.HWCFG is updated with the content of SWCFG upon an Application Reset                 |
| <b>SWRSTREQ</b> | 1      | w    | <b>Software Reset Request</b><br>$0_B$ No software reset is requested<br>$1_B$ A software reset request trigger is generated                                                                                                                                   |
| <b>SWCFG</b>    | [15:8] | rw   | <b>Software Boot Configuration</b><br>A valid software boot configuration (also different from the external applied hardware configuration) can be specified with these bits.<br>The configuration encoding is equal to the HWCFG encoding in register STSTAT. |
| <b>0</b>        | [7:2]  | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                        |

## 8.5 External Service Request (ESR) Pins

The ESR pins serve as multi-functional pins for an amount of different options:

- Act as reset trigger input
- Act as reset output
- Act as trap input
- Act as trigger input for the GSC
- Independent pad configuration

### 8.5.1 General Operation

Each ESR pin is equipped with an edge detection that allows the selection of the edges used as triggers. One, both, or no edge can be selected via bit field ESRCFGx.SEDCON if a clock is active. Additionally, there is a digital (3-stage median) filter (DF) to suppress spikes. The signal at ESRx pin has to be held at the active signal level for at least 2 system clock cycles ( $f_{SYS}$ ) in order to generate a trigger. The digital filter can be disabled by clearing bit ESRCFGx.DFEN.

Each ESRx pin can be individually configured.

If an ESR trigger is generated please note that triggers for all purposes (reset, trap, GSC, and non SCU module functions) are generated. If some of the actions resulting out of such a trigger should not occur this has to be disabled by each feature for its own.

The pins that should be used as trigger input for an ESR operation have to be configured as input pin.

## System Control Unit (SCU)


**Figure 8-19 ESRx Control**

Up to three **ESR** pins (**ESR0/ESR1/ESR2**) are available. The availability of pins **ESR1** and **ESR2** is device and package dependent and is described in the data sheet.

### 8.5.1.1 ESR as Reset Input

The pins ESR<sub>x</sub> can serve as an external reset input as well as a reset output (open drain) for Internal Application and Application Resets. Additionally several GPIO pad triggers that can be enabled additionally via register ESREXCON<sub>x</sub> interfere with the ESR pin function. GPIO and ESR pin triggers can be enabled/disabled individually and are combined for the reset trigger generation. For more information about the reset system see [Chapter 8.4](#).

*Note: The reset output is only asserted for the duration the reset counter RSTCNTA is active. During a possible reset extension the reset output is not longer asserted.*

### 8.5.1.2 ESR as Reset Output

If pin ESR<sub>x</sub> is enabled as reset output and the input level is low while the output stage is disabled (indicating that it is still driven low externally), the reset circuitry holds the chip in reset until a high level is detected on ESRx. The internal output stage drives a low level during reset only while RSTCNTA is active. It deactivates the output stage when the time defined by RSTCNTCON.RELA has passed. For more information about the reset system see [Chapter 8.4](#).

### 8.5.1.3 ESR as Trap Trigger

The ESR can request traps. The control mechanism if and which trap is requested is located in the trap control logic. For more information see [Chapter 8.13](#).

### 8.5.1.4 ESR as Trigger Input for the GSC

The ESR can be used to request a change in the Control Mode. For more information see [Chapter 8.7](#).

### 8.5.1.5 Pad Configuration for ESR Pads

The configuration is selected via bit field ESRCFGx.PC.

The pad functionality control can be configured independently for each pin, comprising:

- A selection of the driver type (open-drain or push-pull)
- An enable function for the output driver (input and/or output capability)
- An enable function for the pull-up/down resistance

The following table defines the coding of the bit fields PC in registers ESRCFG0, ESRCFG1, and ESRCFG2.

*Note: The coding is the same as for the port register bit fields Pn\_IOCRx.PC.*

**Table 8-6 PC Coding**

| PCx[3:0]          | Selected Pull-up/Pull-down / Selected Output Function               | I/O                                                                      | Output Characteristics                                                           |
|-------------------|---------------------------------------------------------------------|--------------------------------------------------------------------------|----------------------------------------------------------------------------------|
| 0000 <sub>B</sub> | No pull device activated                                            | Input is not inverted,<br>the input stage is active in power-down mode   |                                                                                  |
| 0001 <sub>B</sub> | Pull-down device activated                                          |                                                                          |                                                                                  |
| 0010 <sub>B</sub> | Pull-up device activated                                            |                                                                          |                                                                                  |
| 0011 <sub>B</sub> | No pull device activated                                            |                                                                          |                                                                                  |
| 0100 <sub>B</sub> | No pull device activated                                            | Input is inverted,<br>the input stage is active in power-down mode       |                                                                                  |
| 0101 <sub>B</sub> | Pull-down device activated                                          |                                                                          |                                                                                  |
| 0110 <sub>B</sub> | Pull-up device activated                                            |                                                                          |                                                                                  |
| 0111 <sub>B</sub> | No pull device activated                                            |                                                                          |                                                                                  |
| 1000 <sub>B</sub> | Output of ESRCFGx.OUT                                               | Output,<br>the input stage is not inverted and active in power-down mode | Push-pull                                                                        |
| 1001 <sub>B</sub> | Output of ESRCFGx.OUT                                               |                                                                          |                                                                                  |
| 1010 <sub>B</sub> | Output drives a 0 for an Internal Application Reset, a 1 otherwise. |                                                                          |                                                                                  |
| 1011 <sub>B</sub> | Output drives a 0 for an Application Reset, a 1 otherwise.          |                                                                          |                                                                                  |
| 1100 <sub>B</sub> | Output of ESRCFGx.OUT                                               |                                                                          | Open-drain,<br>a pull-up device is activated while the output is not driving a 0 |
| 1101 <sub>B</sub> | Output of ESRCFGx.OUT                                               |                                                                          |                                                                                  |
| 1110 <sub>B</sub> | Output drives a 0 for an Internal Application Reset                 |                                                                          |                                                                                  |
| 1111 <sub>B</sub> | Output drives a 0 for an Application Reset                          |                                                                          |                                                                                  |

## 8.5.2 ESR Control Registers

### 8.5.2.1 Configuration Registers

#### ESR External Control Register

**ESREXCON1**

**ESR1 External Control Register**

SFR (FF32<sub>H</sub>/99<sub>H</sub>)

Reset Value: 0001<sub>H</sub>

**ESREXCON2**

**ESR2 External Control Register**

SFR (FF34<sub>H</sub>/9A<sub>H</sub>)

Reset Value: 0001<sub>H</sub>



| Field        | Bits   | Type | Description                                                                                                                                                                                               |
|--------------|--------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ESREN</b> | 0      | rw   | <b>ESRy Pin Enable</b><br>This bit enables/disables the ESRy pin for the activation of all ESRy related actions.<br>$0_B$ The input from pin ESRy is disabled<br>$1_B$ The input from pin ESRy is enabled |
| <b>0</b>     | [15:1] | rw   | <b>Reserved</b><br>Must be written with reset value 0.                                                                                                                                                    |

## System Control Unit (SCU)

**ESREXSTAT1**
**ESR1 External Status Register SFR (FF36<sub>H</sub>/9B<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**
**ESREXSTAT2**
**ESR2 External Status Register SFR (FF38<sub>H</sub>/9C<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**


| Field      | Bits   | Type | Description                                                                                                                                                                                                                                                                                                                          |
|------------|--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ESR</b> | 0      | rh   | <p><b>Input ESRy Status</b><br/>                     This bit is set upon a trigger on input x if ESREXCONy.ESREN was set. This bit can be cleared only by software.</p> <p><b>0<sub>B</sub></b> No trigger for <u>ESRy</u> occurred<br/> <b>1<sub>B</sub></b> A trigger for <u>ESRy</u> occurred since it was cleared last time</p> |
| <b>0</b>   | [15:1] | r    | <p><b>Reserved</b><br/>                     Read as 0; should be written with 0.</p>                                                                                                                                                                                                                                                 |

## System Control Unit (SCU)

**CLRESREXSTAT1**
**Clear ESR1 External Status RegisterSFR (FF3A<sub>H</sub>/9D<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**
**CLRESREXSTAT2**
**Clear ESR2 External Status RegisterSFR (FF3C<sub>H</sub>/9E<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**


| Field      | Bits   | Type | Description                                                                                                                                                                  |
|------------|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ESR</b> | 0      | w    | <b>Clear Input ESRy Status</b><br>Setting this bit clears the bit ESREXSTATy.ESR.<br>This bit always read as zero.<br>$0_B$ No effect<br>$1_B$ Bit ESREXSTATy.ESR is cleared |
| <b>0</b>   | [15:1] | w    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                      |

## System Control Unit (SCU)

**ESR Configuration Register**

The ESR configuration registers contains bits required for the behavioral control of the ESR pins.

**ESRCFG0**

**ESR0 Configuration Register**    **ESFR (F100<sub>H</sub>/80<sub>H</sub>)**                  **Reset Value: 000E<sub>H</sub>**

**ESRCFG1**

**ESR1 Configuration Register**    **ESFR (F102<sub>H</sub>/81<sub>H</sub>)**                  **Reset Value: 0002<sub>H</sub>**

**ESRCFG2**

**ESR2 Configuration Register**    **ESFR (F104<sub>H</sub>/82<sub>H</sub>)**                  **Reset Value: 0002<sub>H</sub>**



| Field | Bits  | Type | Description                                                                                                                                                                                                                           |
|-------|-------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PC    | [3:0] | rw   | <b>Pin Control of ESRx</b><br>This bit field controls the behavior of the associated ESRx pin.<br>The coding is described in <a href="#">Table 8-6</a> .                                                                              |
| DFEN  | 4     | rw   | <b>Digital Filter Enable</b><br>This bit defines if the 3-stage median filter of the ESRx is used or bypassed.<br>$0_B$ The filter is bypassed<br>$1_B$ The filter is used                                                            |
| OUT   | 5     | rh   | <b>Data Output</b><br>This bit can be used as output value for the associated ESRx pin.<br>$0_B$ If selected, the output level is 0<br>$1_B$ If selected, the output level is 1<br>This bit is controlled via bit field ESRDAT.MOUTx. |
| IN    | 6     | rh   | <b>Data Input</b><br>This bit monitors the input value at the associated ESRx pin.                                                                                                                                                    |

## System Control Unit (SCU)

| Field         | Bits    | Type | Description                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------|---------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>SEDCON</b> | [8:7]   | rw   | <b>Synchronous Edge Detection Control</b><br>This bit field defines the edges that lead to an <u>ESRx</u> trigger of the synchronous path.<br>00 <sub>B</sub> No trigger is generated<br>01 <sub>B</sub> A trigger is generated upon a raising edge<br>10 <sub>B</sub> A trigger is generated upon a falling edge<br>11 <sub>B</sub> A trigger is generated upon a raising AND falling edge |
| <b>0</b>      | [10:9]  | rw   | <b>Reserved</b><br>Must be written with reset value 00 <sub>B</sub> .                                                                                                                                                                                                                                                                                                                       |
| <b>0</b>      | [15:11] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                                                                                     |

## 8.5.3 ESR Data Register

### 8.5.3.1 ESRDAT

The ESR data register contains bits required if ESRx are used as data ports.

#### ESRDAT

##### ESR Data Register

##### ESFR ( $F106_H/83_H$ )

**Reset Value:**  $0000_H$



| Field        | Bits   | Type | Description                                                                                                                                                                                                                                                                                                                             |
|--------------|--------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>MOUT0</b> | [1:0]  | w    | <b>Modification of ESRCFG0.OUT</b><br>Writing to this bit field can modify the content of bit ESRCFG0.OUT for ESR0. It always reads 0.<br>00 <sub>B</sub> Bit ESRCFG0.OUT is unchanged<br>01 <sub>B</sub> Bit ESRCFG0.OUT is set<br>10 <sub>B</sub> Bit ESRCFG0.OUT is cleared<br>11 <sub>B</sub> Reserved, do not use this combination |
| <b>MOUT1</b> | [3:2]  | w    | <b>Modification of ESRCFG1.OUT</b><br>Writing to this bit field can modify the content of bit ESRCFG1.OUT for ESR1. It always reads 0.<br>00 <sub>B</sub> Bit ESRCFG1.OUT is unchanged<br>01 <sub>B</sub> Bit ESRCFG1.OUT is set<br>10 <sub>B</sub> Bit ESRCFG1.OUT is cleared<br>11 <sub>B</sub> Reserved, do not use this combination |
| <b>MOUT2</b> | [5:4]  | w    | <b>Modification of ESRCFG2.OUT</b><br>Writing to this bit field can modify the content of bit ESRCFG2.OUT for ESR2. It always reads 0.<br>00 <sub>B</sub> Bit ESRCFG2.OUT is unchanged<br>01 <sub>B</sub> Bit ESRCFG2.OUT is set<br>10 <sub>B</sub> Bit ESRCFG2.OUT is cleared<br>11 <sub>B</sub> Reserved, do not use this combination |
| <b>0</b>     | [15:6] | w    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                                 |

## System Control Unit (SCU)

### 8.6 Power Supply and Control

The XC27x5X can run from a single external power supply. The core supply voltages can be generated by on-chip Embedded Voltage Regulators (EVRs).

#### Power Domains

The I/O part is divided in two parts DMP\_A and DMP\_B. DMP\_A contains all ADC related I/Os and DMP\_B the remaining system and communication I/Os.

The major part of the on-chip logic is located in an independent core power domain (DMP\_1). A second power domain (DMP\_M), marked grey in the figure below, controls important device infrastructure plus a Standby RAM (SBRAM).



**Figure 8-20 XC27x5X Power Domain Structure**

#### Power Supply and Control Functions

The power supply and control is divided into following parts:

- monitoring of the supply voltage
- controlling and adjusting the supply voltage

## System Control Unit (SCU)

The supply voltage of pad IO domain for system and communication I/Os (power domain DMP\_B) is monitored by a Supply WatchDog (SWD, see [Chapter 8.6.1](#)).

The core voltage for each of the two core supply domains is supervised by a separate Power Validation Circuit (PVC) that provides two monitoring levels. Each monitoring level can request an interrupt (e.g. power-fail warning) or a reset depending on the voltage level. A PVC is used to detect under voltage due to an external short (see [Chapter 8.6.2](#)).

By controlling the regulator, the core power can be switched off to save the leakage current (see [Chapter 8.6.3](#)).

**Table 8-7 XC27x5X Power Domains Supply and Control**

| Power Domain                  | Supply Source   | Supply Voltage [V]                                  | Supply Checked by |
|-------------------------------|-----------------|-----------------------------------------------------|-------------------|
| Pad IO domain (DMP_B)         | External supply | $V_{DDPB}$ : 3.0 ... 5.5 typ<br>See data sheet      | SWD               |
| ADC IO domain (DMP_A)         | External supply | $V_{DDPA}$ : 3.0 ... 5.5 typ<br>See data sheet      | -                 |
| Core domain (DMP_M and DMP_1) | EVR_M<br>EVR_1  | $V_{DDIM}$ , $V_{DDI1}$ : 1.5 typ<br>See data sheet | PVC_1,<br>PVC_M   |

### 8.6.1 Supply Watchdog (SWD)

The supply voltage of the pad I/O domain for systems and communication I/Os (DMP\_B) is monitored to validate the overall power supply. The external supply voltage is monitored for following purposes:

- POR  
Detecting the ramp-up of the external supply voltage, so the device can be started without requiring an external power-on reset (PORST).
- Brown-out  
Detecting the ramp-down of the external supply voltage, so the device can be brought into a save state without requiring an external power-on reset (PORST).
- Monitoring the external power supply allows the usage of a low-cost regulator without additional status signals (standard 3-pin device).
- Guarantee that the supply voltage for the EVRs is sufficient to generate a valid core voltage under every operating condition

#### Feature list

The following list is a summary of the SWD functions.

- Trigger a power-on reset whenever the supply falls and as long as the supply remains below  $V_{VAL}$
- Two completely independent threshold levels and comparators
- 16 selectable threshold levels
- Power Saving Mode (only  $V_{VAL}$  detection active)

## Operating the SWD



**Figure 8-21 SWD Power Validation Example**

The lower fix threshold  $V_{VAL}$  defines the absolute minimum operation voltage for the IO domain. If  $V_{VAL}$  has not been reached the device is held in reset. When  $V_{DDPB}$  raises above  $V_{VAL}$ , bit **SWDCON1.PON** is set.

*Note: The physical value for  $V_{VAL}$  can found in the XC27x5X data sheet.*

The SWD provides two adjustable threshold levels (LEV1 and LEV2) that can be individually programmed, via **SWDCON0.LEV1V** and **SWDCON0.LEV2V**, and deliver a compare value each. The two compare results can be monitored via bits **SWDCON0.L1OK** and **SWDCON0.L2OK**. A reset or interrupt request can be generated while the voltage level is below or equal/above the configured level of a threshold. If an action and which action is triggered by each threshold can be configured via bits

## System Control Unit (SCU)

SWDCON0.LxRSTEN and SWDCON0.LxINTEN and bit field SWDCON0.LxALEV ( $x = 1,2$ ).

The SWD control (programming of the threshold levels) is done by software only.

With these features, an external supply watchdog, e.g. integrated in some external VR, can be replaced. It detects the minimum specified supply voltage level and can be configured to monitor other voltage levels.

*Note: If the PORST pin is used it has the same functionality as the min-power detection of the SWD.*

### Power-Saving Mode of the SWD

The two configurable thresholds can be disabled if not needed. This is called the SWD Power Saving Mode. The minimum operating voltage detection (POR/Brown-out detection) can not be disabled and it is always active. The SWD Power Saving Mode is entered by setting bit **SWDCON1.POWENSET** and exit by setting bit SWDCON1.POWENCLR. If the SWD Power Saving Mode is active is indicated by bit SWDCON1.POWEN.

*Note: The reset request and interrupt request action should be switched off before entering power-save mode.*

## System Control Unit (SCU)

### 8.6.1.1 SWD Control Registers

The following registers are the software interface for the SWD.

#### SWDCON0

##### SWD Control 0 Register

##### ESFR (F080<sub>H</sub>/40<sub>H</sub>)

Reset Value: 0941<sub>H</sub>

| 15             | 14              | 13              | 12       | 11    | 10 | 9 | 8 | 7              | 6               | 5               | 4        | 3     | 2 | 1 | 0 |
|----------------|-----------------|-----------------|----------|-------|----|---|---|----------------|-----------------|-----------------|----------|-------|---|---|---|
| L2<br>A<br>LEV | L2<br>RST<br>EN | L2<br>INT<br>EN | L2<br>OK | LEV2V |    |   |   | L1<br>A<br>LEV | L1<br>RST<br>EN | L1<br>INT<br>EN | L1<br>OK | LEV1V |   |   |   |
| rw             | rw              | rw              | rh       | rw    |    |   |   | rw             | rw              | rw              | rh       | rw    |   |   |   |

| Field   | Bits  | Type | Description                                                                                                                                                                                                                                      |
|---------|-------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LEV1V   | [3:0] | rw   | <b>Level Threshold 1 Voltage</b><br>This bit field defines the voltage level that is used as threshold 1 check level.<br>The values of the level thresholds are listed in the data sheet.                                                        |
| L1OK    | 4     | rh   | <b>Level Threshold 1 Check Result</b><br>$0_B$ The supply voltage is below the Level Threshold 1 voltage LEV1V<br>$1_B$ The supply voltage is equal or above the Level Threshold 1 voltage LEV1V                                                 |
| L1INTEN | 5     | rw   | <b>Level Threshold 1 Interrupt Request Enable</b><br>This bit field defines if an interrupt is requested if the supply voltage comparison matches the action level L1ALEV.<br>$0_B$ No interrupt is requested<br>$1_B$ An interrupt is requested |
| L1RSTEN | 6     | rw   | <b>Level Threshold 1 Reset Request Enable</b><br>This bit field defines if an interrupt is requested if the supply voltage comparison matches the action level L1ALEV.<br>$0_B$ No reset is requested<br>$1_B$ An reset is requested             |

## System Control Unit (SCU)

| Field   | Bits   | Type | Description                                                                                                                                                                                                                                                                                                                                                    |
|---------|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| L1ALEV  | 7      | rw   | <b>Level Threshold 1 Action Level</b><br>0 <sub>B</sub> When the supply voltage is below the Level Threshold 1 voltage LEV1V the actions configured by bits L1INTEN and L1RSTEN are requested<br>1 <sub>B</sub> When the supply voltage is equal or above the Level Threshold 1 voltage LEV1V the actions configured by bits L1INTEN and L1RSTEN are requested |
| LEV2V   | [11:8] | rw   | <b>Level Threshold 2 Voltage</b><br>This bit field defines the voltage level that is used as check level threshold 2.<br>The values of the level thresholds are listed in the data sheet.                                                                                                                                                                      |
| L2OK    | 12     | rh   | <b>Level Threshold 2 Check Result</b><br>0 <sub>B</sub> The supply voltage is below the Level Threshold 2 voltage LEV2V<br>1 <sub>B</sub> The supply voltage is equal or above the Level Threshold 2 voltage LEV2V                                                                                                                                             |
| L2INTEN | 13     | rw   | <b>Level Threshold 2 Interrupt Request Enable</b><br>This bit field defines if an interrupt is requested if the supply voltage comparison matches the action level L2ALEV.<br>0 <sub>B</sub> No interrupt is requested<br>1 <sub>B</sub> An interrupt is requested                                                                                             |
| L2RSTEN | 14     | rw   | <b>Level Threshold 2 Reset Request Enable</b><br>This bit field defines if an interrupt is requested if the supply voltage comparison matches the action level L2ALEV.<br>0 <sub>B</sub> No reset is requested<br>1 <sub>B</sub> An reset is requested                                                                                                         |

## System Control Unit (SCU)

| Field  | Bits | Type | Description                                                                                                                                                                                                                                                                                                                                                                |
|--------|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| L2ALEV | 15   | rw   | <b>Level Threshold 2 Action Level</b><br><b>0<sub>B</sub></b> When the supply voltage is below the Level Threshold 2 voltage LEV2V the actions configured by bits L2INTEN and L2RSTEN are requested<br><b>1<sub>B</sub></b> When the supply voltage is equal or above the Level Threshold 2 voltage LEV2V the actions configured by bits L2INTEN and L2RSTEN are requested |

## **System Control Unit (SCU)**

SWDCON1

## **SWD Control 1 Register**

ESFR (F082<sub>H</sub>/41<sub>H</sub>)

**Reset Value: 0000<sub>H</sub>**

Bitmask diagram for the PON register:

- Bits 15 to 1 are labeled from left to right: 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0.
- The bit at position 0 is labeled "0".
- Below the bits, the labels are grouped into four columns:
  - Column 1: CLR\_PON (bit 4)
  - Column 2: PON (bit 3)
  - Column 3: POW\_EN (bit 2)
  - Column 4: POW\_EN\_SET (bit 1)
  - Column 5: POW\_EN\_CLR (bit 0)
- Below the columns, the labels are grouped into three rows:
  - Row 1: w (under CLR\_PON), rh (under PON), rh (under POW\_EN)
  - Row 2: w (under POW\_EN\_SET)
  - Row 3: w (under POW\_EN\_CLR)

| Field           | Bits   | Type | Description                                                                                                                                                              |
|-----------------|--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>POWENCLR</b> | 0      | w    | <b>SWD Power Saving Mode Enable Clear</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit POWEN is cleared                                                             |
| <b>POWENSET</b> | 1      | w    | <b>SWD Power Saving Mode Enable Set</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit POWEN is set                                                                   |
| <b>POWEN</b>    | 2      | rh   | <b>SWD Power Saving Mode Enable</b><br>0 <sub>B</sub> All SWD functions are enabled<br>1 <sub>B</sub> The SWD Power Saving Mode is enabled.<br>Comparators are disabled. |
| <b>PON</b>      | 3      | rh   | <b>Power-On Status Flag</b><br>0 <sub>B</sub> No power-on event occurred<br>1 <sub>B</sub> A power-on event occurred ( $V_{DDP}$ became greater than $V_{VAL}$ ).        |
| <b>CLRPON</b>   | 4      | w    | <b>Clear Power-On Status Flag</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit PON is cleared                                                                       |
| <b>0</b>        | [15:5] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                  |

## System Control Unit (SCU)

### 8.6.2 Monitoring the Voltage Level of a Core Domain

A Power Validation Circuit (PVC) monitors the internal core supply voltage of a core domain. It can be configured to monitor two programmable independent voltage levels. The voltage of the core domain is monitored by PVC\_1 and PVC\_M.

#### Feature list

The following list summarizes the features of a PVC.

- Two independent comparators
- Threshold levels selectable
- Shut-off, which disables the complete module
- Configurable action level

A PVC provides two adjustable threshold levels (LEV1 and LEV2) that can be individually programmed via PVCxCON0.LEV1V and PVCxCON0.LEV2V ( $x = M$  or 1) PVC1CON0.LEV1V and PVC1CON0.LEV2V. The current supply level of a domain is compared with the threshold values. The two compare results can be monitored via bits PVCxCON0.LEV1OK and PVCxCON0.LEV2OK ( $x = M$  or 1) PVC1CON0.LEV1OK and PVC1CON0.LEV2OK

A reset or interrupt request can be generated in case the core domain voltage level is below or equal / above the configured threshold level. An interrupt is requested if bit PVCxCON0.L1INTEN and / or PVCxCON0.L2INTEN ( $x = M$  or 1) PVC1CON0.L1INTEN and / or PVC1CON0.L2INTEN is set. A reset is requested if bit PVCxCON0.L1RSTEN and / or PVCxCON0.L2RSTEN ( $x = M$  or 1) PVC1CON0.L1RSTEN and / or PVC1CON0.L2RSTEN is set.

*Note: For a single threshold both interrupt and reset request generation should not be enabled at the same time.*

## System Control Unit (SCU)

### 8.6.2.1 PVC Status and Control Registers

These registers are the software interface for PVC\_1 and PVC\_M.

#### PVC1CON0

##### PVC\_1 Control Step 0 Register

| ESFR (F014 <sub>H</sub> /0A <sub>H</sub> ) |     |     |     |     |    |       |   |    |     |     |     |     |    |       | Reset Value: 0504 <sub>H</sub> |  |  |  |
|--------------------------------------------|-----|-----|-----|-----|----|-------|---|----|-----|-----|-----|-----|----|-------|--------------------------------|--|--|--|
| 15                                         | 14  | 13  | 12  | 11  | 10 | 9     | 8 | 7  | 6   | 5   | 4   | 3   | 2  | 1     | 0                              |  |  |  |
| L2                                         | L2  | L2  | L2  | LEV |    | LEV2V |   | L1 | L1  | L1  | L1  | LEV |    | LEV1V |                                |  |  |  |
| AS                                         | RST | INT | A   | 2   | OK |       |   | AS | RST | INT | A   | 1   | OK |       |                                |  |  |  |
| EN                                         | EN  | EN  | LEV |     |    |       |   | EN | EN  | EN  | LEV |     |    |       |                                |  |  |  |
| rw                                         | rw  | rw  | rw  | rh  |    | rw    |   | rw | rw  | rw  | rw  | rh  |    | rw    |                                |  |  |  |

| Field   | Bits  | Type | Description                                                                                                                                                                                                                                                                                                                                                     |
|---------|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LEV1V   | [2:0] | rw   | <b>Level Threshold 1 Voltage</b><br>This bit field defines the Level Threshold 1 that is compared with the DMP_1 core voltage.<br>The values for the different configurations are listed in the data sheet.                                                                                                                                                     |
| LEV1OK  | 3     | rh   | <b>Level Threshold 1 Check Result</b><br>$0_B$ The core supply voltage of the DMP_1 is below Level Threshold 1 voltage LEV1V<br>$1_B$ The core supply voltage of the DMP_1 is equal or above the Level Threshold 1 voltage LEV1V                                                                                                                                |
| L1ALEV  | 4     | rw   | <b>Level Threshold 1 Action Level</b><br>$0_B$ When the core supply voltage is below Level Threshold 1 voltage LEV1V the action configured by bits L1INTEN, L1RSTEN, and L1ASEN are requested<br>$1_B$ When the core supply voltage is equal or above Level Threshold 1 voltage LEV1V the actions configured by bits L1INTEN, L1RSTEN, and L1ASEN are requested |
| L1INTEN | 5     | rw   | <b>Level Threshold 1 Interrupt Request Enable</b><br>This bit defines if an interrupt request trigger is requested if the comparison check was successful.<br>When a check is successful is defined via bit L1ALEV.<br>$0_B$ No interrupt is requested<br>$1_B$ An interrupt is requested                                                                       |

## System Control Unit (SCU)

| Field   | Bits   | Type | Description                                                                                                                                                                                                                                                                                                                                                                              |
|---------|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| L1RSTEN | 6      | rw   | <b>Level Threshold 1 Reset Request Enable</b><br>This bit defines if a reset request trigger is requested if the comparison check was successful. When a check is successful is defined via bit L1ALEV.<br>0 <sub>B</sub> No reset is requested<br>1 <sub>B</sub> An reset is requested                                                                                                  |
| L1ASEN  | 7      | rw   | <b>Level Threshold 1 Asynchronous Action Enable</b><br>This bit defines if asynchronous action can be performed if the comparison check was successful. When a check is successful is defined via bit L1ALEV.<br>0 <sub>B</sub> No asynchronous actions are performed<br>1 <sub>B</sub> Asynchronous actions can be performed                                                            |
| LEV2V   | [10:8] | rw   | <b>Level Threshold 2 Voltage</b><br>This bit field defines the level of threshold 2 that is compared with the DMP_1 core voltage..<br>The values for the different configurations are listed in the data sheet.                                                                                                                                                                          |
| LEV2OK  | 11     | rh   | <b>Level Threshold 2 Check Result</b><br>0 <sub>B</sub> The core supply voltage of the DMP_1 is below the Level Threshold 2 LEV2V<br>1 <sub>B</sub> The core supply voltage of the DMP_1 is equal or above the Level Threshold 2 LEV2V                                                                                                                                                   |
| L2ALEV  | 12     | rw   | <b>Level Threshold 2 Action Level</b><br>0 <sub>B</sub> When the core supply voltage is below the Level Threshold 2 voltage LEV2V the action configured by bits L2INTEN, L2RSTEN, and L2ASEN are requested<br>1 <sub>B</sub> When the core supply voltage is equal or above the Level Threshold 2 voltage LEV2V the action configured by bits L2INTEN, L2RSTEN, and L2ASEN are requested |
| L2INTEN | 13     | rw   | <b>Level Threshold 2 Interrupt Request Enable</b><br>This bit defines if an interrupt request trigger is requested if the comparison check was successful. When a check is successful is defined via bit L2ALEV.<br>0 <sub>B</sub> No interrupt is requested<br>1 <sub>B</sub> An interrupt is requested                                                                                 |

## System Control Unit (SCU)

| Field   | Bits | Type | Description                                                                                                                                                                                                                                                                                                                   |
|---------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| L2RSTEN | 14   | rw   | <b>Level Threshold 2 Reset Request Enable</b><br>This bit defines if a reset request trigger is requested if the comparison check was successful. When a check is successful is defined via bit L2ALEV.<br>0 <sub>B</sub> No reset is requested<br>1 <sub>B</sub> An reset is requested                                       |
| L2ASEN  | 15   | rw   | <b>Level Threshold 2 Asynchronous Action Enable</b><br>This bit defines if asynchronous action can be performed if the comparison check was successful. When a check is successful is defined via bit L2ALEV.<br>0 <sub>B</sub> No asynchronous actions are performed<br>1 <sub>B</sub> Asynchronous actions can be performed |

## System Control Unit (SCU)

**PVCMCON0**
**PVC\_M Control Step 0 Register**

| MEM (F1E4 <sub>H</sub> /--) |                 |                 |                |                |       |   |    |                |                 |                 |                |                |       |   | Reset Value: 0544 <sub>H</sub> |    |    |    |
|-----------------------------|-----------------|-----------------|----------------|----------------|-------|---|----|----------------|-----------------|-----------------|----------------|----------------|-------|---|--------------------------------|----|----|----|
| 15                          | 14              | 13              | 12             | 11             | 10    | 9 | 8  | 7              | 6               | 5               | 4              | 3              | 2     | 1 | 0                              |    |    |    |
| L2<br>AS<br>EN              | L2<br>RST<br>EN | L2<br>INT<br>EN | L2<br>A<br>LEV | LEV<br>2<br>OK | LEV2V |   | rw | L1<br>AS<br>EN | L1<br>RST<br>EN | L1<br>INT<br>EN | L1<br>A<br>LEV | LEV<br>1<br>OK | LEV1V |   | rw                             | rw | rw | rw |
| rw                          | rw              | rw              | rw             | rh             | rw    |   | rw | rw             | rw              | rw              | rw             | rh             | rw    |   | rw                             | rw | rw | rw |

| Field   | Bits  | Type | Description                                                                                                                                                                                                                                                                                                                                                     |
|---------|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LEV1V   | [2:0] | rw   | <b>Level Threshold 1 Voltage</b><br>This bit field defines the Level Threshold 1 that is compared with the DMP_M core supply voltage. The values for the different configurations are listed in the data sheet.                                                                                                                                                 |
| LEV1OK  | 3     | rh   | <b>Level Threshold 1 Check Result</b><br>$0_B$ The core supply voltage of the DMP_M is below Level Threshold 1 voltage LEV1V<br>$1_B$ The core supply voltage of the DMP_M is equal or above the Level Threshold 1 voltage LEV1V                                                                                                                                |
| L1ALEV  | 4     | rw   | <b>Level Threshold 1 Action Level</b><br>$0_B$ When the core supply voltage is below Level Threshold 1 voltage LEV1V the action configured by bits L1INTEN, L1RSTEN, and L1ASEN are requested<br>$1_B$ When the core supply voltage is equal or above Level Threshold 1 voltage LEV1V the actions configured by bits L1INTEN, L1RSTEN, and L1ASEN are requested |
| L1INTEN | 5     | rw   | <b>Level Threshold 1 Interrupt Request Enable</b><br>This bit defines if an interrupt request trigger is requested if the comparison check was successful. When a check is successful is defined via bit L1ALEV.<br>$0_B$ No interrupt is requested<br>$1_B$ An interrupt is requested                                                                          |

## System Control Unit (SCU)

| Field   | Bits   | Type | Description                                                                                                                                                                                                                                                                                                                                                                              |
|---------|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| L1RSTEN | 6      | rw   | <b>Level Threshold 1 Reset Request Enable</b><br>This bit defines if a reset request trigger is requested if the comparison check was successful. When a check is successful is defined via bit L1ALEV.<br>0 <sub>B</sub> No reset is requested<br>1 <sub>B</sub> An reset is requested                                                                                                  |
| L1ASEN  | 7      | rw   | <b>Level Threshold 1 Asynchronous Action Enable</b><br>This bit defines if asynchronous action can be performed if the comparison check was successful. When a check is successful is defined via bit L1ALEV.<br>0 <sub>B</sub> No asynchronous actions are performed<br>1 <sub>B</sub> Asynchronous actions can be performed                                                            |
| LEV2V   | [10:8] | rw   | <b>Level Threshold 2 Voltage</b><br>This bit field defines the Level Threshold 2 that is compared with the DMP_M core supply voltage. The values for the different configurations are listed in the data sheet.                                                                                                                                                                          |
| LEV2OK  | 11     | rh   | <b>Level Threshold 2 Check Result</b><br>0 <sub>B</sub> The core supply voltage of the DMP_M is below Level Threshold 2 voltage LEV2V<br>1 <sub>B</sub> The core supply voltage of the DMP_M is equal or above the Level Threshold 2 voltage LEV2V                                                                                                                                       |
| L2ALEV  | 12     | rw   | <b>Level Threshold 2 Action Level</b><br>0 <sub>B</sub> When the core supply voltage is below the Level Threshold 2 voltage LEV2V the action configured by bits L2INTEN, L2RSTEN, and L2ASEN are requested<br>1 <sub>B</sub> When the core supply voltage is equal or above the Level Threshold 2 voltage LEV2V the action configured by bits L2INTEN, L2RSTEN, and L2ASEN are requested |
| L2INTEN | 13     | rw   | <b>Level Threshold 2 Interrupt Request Enable</b><br>This bit defines if an interrupt request trigger is requested if the comparison check was successful. When a check is successful is defined via bit L2ALEV.<br>0 <sub>B</sub> No interrupt is requested<br>1 <sub>B</sub> An interrupt is requested                                                                                 |

## System Control Unit (SCU)

| Field   | Bits | Type | Description                                                                                                                                                                                                                                                                                                                   |
|---------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| L2RSTEN | 14   | rw   | <b>Level Threshold 2 Reset Request Enable</b><br>This bit defines if a reset request trigger is requested if the comparison check was successful. When a check is successful is defined via bit L2ALEV.<br>0 <sub>B</sub> No reset is requested<br>1 <sub>B</sub> An reset is requested                                       |
| L2ASEN  | 15   | rw   | <b>Level Threshold 2 Asynchronous Action Enable</b><br>This bit defines if asynchronous action can be performed if the comparison check was successful. When a check is successful is defined via bit L2ALEV.<br>0 <sub>B</sub> No asynchronous actions are performed<br>1 <sub>B</sub> Asynchronous actions can be performed |

## System Control Unit (SCU)

### 8.6.3 Controlling the Voltage Level of a Core Domain

The core power can be controlled within certain limits. The voltage level is controlled by two **Embedded Voltage Regulators** (EVR).

The power domain is controlled by both EVR\_M and EVR\_1.

#### 8.6.3.1 Embedded Voltage Regulator

The main part of the device logic operates at a typical voltage level of 1.5 V. This supply voltage is generated by the Embedded Power Regulators (EVRs) out of the pad voltage. External buffer caps are required for stable regulation.

##### Feature list:

- Multiple core voltage levels including zero
- Core voltage generation based on a High Precision Bandgap
- External supply possible via capacitor-pin while EVR is switched-off
- Core current limit

The EVR configurations to select the desired voltage and reference pair are combined within EVR settings EVRxSETyyV (x = M or 1 and yy = 15). Each setting contains a bit field (VRSEL) to select the voltage level and reference and a bit field to fine-tune the voltage level (VLEV). One out of the possible settings is used to control each of the EVRs, but only in the allowed combinations for the two EVRs. The EVRs use a High Precision Bandgap (HP) as reference

The BG voltage of each setting can be adjusted to compensate application and environmental influences by the bit field EVRxSETyyV.VLEV. VLEV is set by default or trimmed by each device during production test to reach the default setting targets.

##### High Precision Bandgap (HP)

The HP bandgap of the system is used for following purposes:

- Provide a very stable reference for the two EVRs
- Provide an accurate reference for the flash memory. For more information see the flash memory description.

The HP bandgap can be enabled / disabled via the bit **EVRMCON1.HPEN**.

## System Control Unit (SCU)

**EVR Status and Control Registers**
**EVR1CON0**
**EVR\_1 Control 0 Register**
**ESFR (F088<sub>H</sub>/44<sub>H</sub>)**
**Reset Value: DF20<sub>H</sub>**

| 15             | 14 | 13 | 12            | 11           | 10 | 9            | 8 | 7 | 6           | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|----|----|---------------|--------------|----|--------------|---|---|-------------|---|---|---|---|---|---|
| <b>EVR DIS</b> | -  | 0  | <b>CC DIS</b> | <b>CCLEV</b> | -  | <b>RES 1</b> | 0 |   | <b>RES0</b> |   |   | 0 |   | r |   |

rh - rw rh rw - rw rw rw rw r

| Field         | Bits    | Type | Description                                                                                                                                                                     |
|---------------|---------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>RES0</b>   | [5:3]   | rw   | <b>Reserved</b><br>Do not change this value when writing to this register.                                                                                                      |
| <b>0</b>      | [7:6]   | rw   | <b>Reserved</b><br>Must be written with reset value 00 <sub>B</sub> .                                                                                                           |
| <b>RES1</b>   | 8       | rw   | <b>Reserved</b><br>Must be written with reset value 1 <sub>B</sub> .                                                                                                            |
| <b>CCLEV</b>  | [11:10] | rw   | <b>Current Control Level</b><br>This bit field is required for enabling/disabling the current control (CCDIS).<br>Valid values are described in the Programmer's Guide.         |
| <b>CCDIS</b>  | 12      | rh   | <b>Current Control Disable</b><br>0 <sub>B</sub> The current control is enabled<br>1 <sub>B</sub> The current control is disabled<br>This bit is updated by bit EVR1SETy.CCDIS. |
| <b>0</b>      | 13      | rw   | <b>Reserved</b><br>Must be written with reset value 0.                                                                                                                          |
| <b>EVRDIS</b> | 15      | rh   | <b>EVR_1 Disable</b><br>0 <sub>B</sub> The EVR_1 is enabled<br>1 <sub>B</sub> The EVR_1 is disabled<br>This bit is updated by bit EVR1SETy.EVRDIS.                              |
| <b>0</b>      | [2:0]   | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                         |

## System Control Unit (SCU)

**EVR1SET15VHP**
**EVR\_1 Setting for 1.5 V HP Register**
**ESFR (F09E<sub>H</sub>/4F<sub>H</sub>)**
**Reset Value: 001B<sub>H</sub>**

|                | 15 | 14 | 13 | 12            | 11 | 10 | 9 | 8          | 7 | 6 | 5 | 4            | 3 | 2 | 1 | 0           |
|----------------|----|----|----|---------------|----|----|---|------------|---|---|---|--------------|---|---|---|-------------|
| <b>EVR DIS</b> |    | 0  |    | <b>CC DIS</b> |    | 0  |   | <b>RES</b> |   | 0 |   | <b>VRSEL</b> |   |   |   | <b>VLEV</b> |

rw            rw

| Field         | Bits  | Type | Description                                                                                                                                                                                                                                                                                                                                                            |
|---------------|-------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>VLEV</b>   | [5:0] | rw   | <b>Voltage Level Adjust</b><br>This bit field adjusts the BG voltage and is trimmed by each device during production test to reach the default setting targets.<br>Do not change this value when writing to this register.                                                                                                                                             |
| <b>VRSEL</b>  | [7:6] | rw   | <b>Voltage Reference Selection</b><br>00 <sub>B</sub> 15VHP - Full Voltage with high precision bandgap selected<br>01 <sub>B</sub> Reserved, do not use this combination<br>10 <sub>B</sub> Reserved, do not use this combination<br>11 <sub>B</sub> Reserved, do not use this combination<br><i>Note: The reset value should always be written to this bit field.</i> |
| <b>RES</b>    | 9     | rw   | <b>Reserved</b><br>Must be written with 1 <sub>B</sub> .                                                                                                                                                                                                                                                                                                               |
| <b>CCDIS</b>  | 12    | rw   | <b>Current Control Disable</b><br>0 <sub>B</sub> The current control is enabled<br>1 <sub>B</sub> The current control is disabled<br>This bit updates bit EVR1CON0.CCDIS.<br><i>Note: Before switching off the current control the CCLEV setting in EVR1CON0 has to be set to 00<sub>B</sub>.</i>                                                                      |
| <b>EVRDIS</b> | 15    | rw   | <b>EVR_1 Disable</b><br>0 <sub>B</sub> The EVR_1 is enabled<br>1 <sub>B</sub> The EVR_1 is disabled<br>This bit updates bit EVR1CON0.EVRDIS.                                                                                                                                                                                                                           |

## System Control Unit (SCU)

| Field | Bits                      | Type | Description                                            |
|-------|---------------------------|------|--------------------------------------------------------|
| 0     | 8,<br>[11:10],<br>[14:13] | rw   | <b>Reserved</b><br>Must be written with reset value 0. |

## System Control Unit (SCU)

**EVRMCON0**
**EVR\_M Control 0 Register**
**ESFR (F084<sub>H</sub>/42<sub>H</sub>)**
**Reset Value: 0D20<sub>H</sub>**

| 15             | 14 | 13            | 12           | 11 | 10           | 9 | 8 | 7 | 6           | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|----|---------------|--------------|----|--------------|---|---|---|-------------|---|---|---|---|---|---|
| <b>EVR DIS</b> | 0  | <b>CC DIS</b> | <b>CCLEV</b> | -  | <b>RES 1</b> | 0 |   |   | <b>RES0</b> |   | 0 |   |   | r |   |

rh r rh rw - rw rw rw rw rw r

| Field         | Bits             | Type | Description                                                                                                                                                                     |
|---------------|------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>RES0</b>   | [5:3]            | rw   | <b>Reserved</b><br>Do not change this value when writing to this register.                                                                                                      |
| <b>0</b>      | [7:6]            | rw   | <b>Reserved</b><br>Must be written with reset value 00 <sub>B</sub> .                                                                                                           |
| <b>RES1</b>   | 8                | rw   | <b>Reserved</b><br>Must be written with 1.                                                                                                                                      |
| <b>CCLEV</b>  | [11:10]          | rw   | <b>Current Control Level</b><br>This bit field is required for enabling/disabling the current control (CCDIS).<br>Valid values are described in the Programmer's Guide.         |
| <b>CCDIS</b>  | 12               | rh   | <b>Current Control Disable</b><br>0 <sub>B</sub> The current control is enabled<br>1 <sub>B</sub> The current control is disabled<br>This bit is updated by bit EVRMSETy.CCDIS. |
| <b>EVRDIS</b> | 15               | rh   | <b>EVR_M Disable</b><br>0 <sub>B</sub> The EVR_M is enabled<br>1 <sub>B</sub> The EVR_M is disabled<br>This bit is updated by bit EVRMSETy.EVRDIS.                              |
| <b>0</b>      | [2:0], 8 [14:13] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                         |

## System Control Unit (SCU)

**EVRMCON1**
**EVR\_M Control 1 Register**
**ESFR (F086<sub>H</sub>/43<sub>H</sub>)**
**Reset Value: 0101<sub>H</sub>**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                | 7               | 6  | 5 | 4 | 3  | 2 | 1 | 0 |  |
|----|----|----|----|----|----|---|------------------|-----------------|----|---|---|----|---|---|---|--|
|    |    |    |    |    |    |   | <b>HP<br/>EN</b> | <b>HPADJUST</b> |    |   |   |    |   |   |   |  |
|    |    |    |    |    |    |   | r                |                 | rw |   |   | rw |   |   |   |  |

| Field           | Bits   | Type | Description                                                                                                                                                   |
|-----------------|--------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>HPADJUST</b> | [7:0]  | rw   | <b>HP Bandgap Adjustment</b><br>This bit field is a device specific trimmvalue for the HP bandgap.<br>Do not change this value when writing to this register. |
| <b>HPEN</b>     | 8      | rw   | <b>HP Bandgap Enable</b><br>$0_B$ The HP bandgap is disabled<br>$1_B$ The HP bandgap is enabled                                                               |
| <b>0</b>        | [15:9] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                       |

## System Control Unit (SCU)

**EVRMSET15VHP**
**EVR\_M Setting for 1.5 V HP Register**
**ESFR (F096<sub>H</sub>/4B<sub>H</sub>)**
**Reset Value: 001B<sub>H</sub>**

|                | 15 | 14 | 13 | 12            | 11 | 10 | 9 | 8            | 7 | 6 | 5            | 4 | 3 | 2 | 1 | 0           |
|----------------|----|----|----|---------------|----|----|---|--------------|---|---|--------------|---|---|---|---|-------------|
| <b>EVR DIS</b> |    | 0  |    | <b>CC DIS</b> |    | 0  |   | <b>RES 0</b> | 0 |   | <b>VRSEL</b> |   |   |   |   | <b>VLEV</b> |

rw            rw

| Field         | Bits  | Type | Description                                                                                                                                                                                                                                                                                                                                                            |
|---------------|-------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>VLEV</b>   | [5:0] | rw   | <b>Voltage Level Adjust</b><br>This bit field adjusts the BG voltage and is trimmed by each device during production test to reach the default setting targets.<br>Do not change this value when writing to this register.                                                                                                                                             |
| <b>VRSEL</b>  | [7:6] | rw   | <b>Voltage Reference Selection</b><br>00 <sub>B</sub> 15VHP - Full Voltage with high precision bandgap selected<br>01 <sub>B</sub> Reserved, do not use this combination<br>10 <sub>B</sub> Reserved, do not use this combination<br>11 <sub>B</sub> Reserved, do not use this combination<br><i>Note: The reset value should always be written to this bit field.</i> |
| <b>RES0</b>   | 9     | rw   | <b>Reserved</b><br>Must be written with 1 <sub>B</sub> .                                                                                                                                                                                                                                                                                                               |
| <b>CCDIS</b>  | 12    | rw   | <b>Current Control Disable</b><br>0 <sub>B</sub> The current control is enabled<br>1 <sub>B</sub> The current control is disabled<br>This bit updates bit EVRMCON0.CCDIS.<br><i>Note: Before switching off the current control the CCLEV setting in EVRMCON0 has to be set to 00<sub>B</sub>.</i>                                                                      |
| <b>EVRDIS</b> | 15    | rw   | <b>EVR_M Disable</b><br>0 <sub>B</sub> The EVR_M is enabled<br>1 <sub>B</sub> The EVR_M is disabled<br>This bit updates bit EVR1CON0.EVRDIS.                                                                                                                                                                                                                           |

## System Control Unit (SCU)

| Field | Bits                      | Type | Description                                            |
|-------|---------------------------|------|--------------------------------------------------------|
| 0     | 8,<br>[11:10],<br>[14:13] | rw   | <b>Reserved</b><br>Must be written with reset value 0. |

### 8.6.3.2 Sources for Core Supply Voltage

The on-chip EVRs can generate the XC27x5X's core supply voltage from the (externally supplied) IO voltage.

#### Core Supply via On-chip EVRs

Generating the core supply voltage via the integrated EVRs is the preferred operating mode, because it saves an additional external voltage regulator. The integrated EVRs are fed from supply voltage  $V_{DDPB}$ .

Proper operation of the EVRs requires external buffer capacitances. Please refer to the respective Data Sheet for the recommended values. The current is delivered by the integrated pass devices.



**Figure 8-22 Selecting the EVR for Core Supply**

Generating the core supply voltage with on-chip resources provides full control of power reduction modes, so the application can control and minimize the energy consumption of the XC27x5X using built-in mechanisms without requiring additional external circuitry.

## System Control Unit (SCU)

### 8.6.4 Handling the Power System

Using the power system correctly is the key to power saving. Depending on the application different operating states can be defined in order to save maximal power. The XC27x5X supports following power saving mechanisms:

- Reduction of the system performance
  - the power consumption depends directly on the frequency of the system
  - the system performance is controlled with the clock operation mechanism
- Stopping single unused peripheral
  - a peripheral not needed for an application can be disabled
  - the module operation is controlled via register MOD\_KSCCFG
- Stopping multiple unused peripherals
  - peripherals not needed for an application can be disabled
  - system peripheral operation is controlled via the Global State Controller (GSC)
- Stopping single unused analog parts
  - an analog part not needed for an application can be stopped
  - the operation is controlled via register either located in the SCU (PLL, clocks, PVCs, SWD, Temperature Compensation) or the ADC

## 8.7 Global State Controller (GSC)

Mode Control for the system peripherals provides besides power saving modes and the clock management an additional opportunity for configuring the system to the application needs.

Mode Control is described in detail in this chapter and is implemented by the Global State Controller (GSC). The GSC enables the user to configure one operating mode in a fast and easy way, reacting fast and explicit to needs of an application.

### Feature Overview

The following issues are handled by the GSC:

- Control of peripheral clock operation
- Suspend control for debugging
- Arbitration between the different request sources

According to the requests coming from the OCDS, the SWD pre-warning detection or other blocks, the GSC does an internal prioritization. The result is forwarded as command request broadcast to all peripherals. The GSC internal prioritization scheme for the implemented request sources is shown in [Table 8-8](#).

### 8.7.1 GSC Control Flow

The sequence begins when at least one request source asserts its trigger in order to request a mode change in the SoC. If several requests are pending there is an arbitration mechanism that treats this issue. Request triggers are not stored by the GSC, therefore a trigger source has to assert its trigger until the trigger is no longer valid or needed.

A request trigger is kept asserted as long as either the request is still pending or the resulting command of the request was entered and acknowledged by the system. The communication of the GSC and the peripherals is based on commands. Three different commands are defined resulting in three modes:

- Wake-up command: requests Normal Mode
- Clock-off command: requests Stop Mode
- Debug command: requests Suspend Mode

The specific behavior in these three modes is defined for each peripheral in its module register mod\_KSCCFG.

#### 8.7.1.1 Request Source Arbitration

The highest priority for the arbitration is zero (see [Table 8-8](#)).

Each system clock cycle a new arbitration round is started. The winner of an arbitration round requests the next command towards the SoC. Please note that winning an arbitration does not lead automatically to a new command raised. Only if currently no command is broadcast in the SoC a new command can be generated and broadcast. If

**System Control Unit (SCU)**

the winner of the arbitration round is the same request trigger as in the previous round or if no winner was detected no new command request is generated.

**Table 8-8 Connection of the Request Sources**

| Request Source | Priority |
|----------------|----------|
| OCDS exit      | 4        |
| ESR0           | 5        |
| ESR1           | 6        |
| ESR2           | 7        |
| WUT            | 8        |
| ITC            | 9        |
| GPT12E         | 10       |
| SW1            | 11       |
| SW2            | 12       |
| OCDS entry     | 14       |

**8.7.1.2 Generation of a New Command**

When a new request trigger was detected and arbitrated a new command request is generated if currently no command request is broadcast that is not received by all slaves.

**Table 8-9 Request Source and Command Request Coupling**

| Request Source | Command Description  |
|----------------|----------------------|
| OCDS exit      | Wake-up; Normal Mode |
| ESR0           | Wake-up; Normal Mode |
| ESR1           | Wake-up; Normal Mode |
| ESR2           | Clock-off; Stop Mode |
| WUT            | Wake-up; Normal Mode |
| ITC            | Wake-up; Normal Mode |
| GPT12E         | Wake-up; Normal Mode |
| SW1            | Wake-up; Normal Mode |
| SW2            | Clock-off; Stop Mode |
| OCDS entry     | Debug; Suspend Mode  |

### 8.7.1.3 Usage of Commands

The complete control mechanism for the different operation modes of the various slaves is divided into two parts:

- A central control and configuration part; the Global State Controller (GSC)
- One local control part in each slave; the Kernel State Controller (KSC)

Via the GSC either different hardware sources (e.g. the WUT or the OCDS) or the software can request the system to enter a specific mode. The parts that are affected by the mode can be pre-defined locally for each part via the KSC. For each command a specific reaction can be pre-configured in each KSC for each individual part.

*Note: Requesting a peripheral to be permanently shut off by clearing mod\_KSCCFG.MODEN to 0 does not start a GSC run. However, a GSC run triggered in parallel to the ramp down of this peripheral will have the FSM of the GSC waiting for an acknowledge also of this peripheral as long as the peripheral does no deliver its acknowledge or the respective bit in GSCPERSTATEN is cleared.*

*The proposal is either to disable automatic GSC runs (by setting GSCEN respectively) in case the application needs the information of the shutdown acknowledge of the peripheral or to disable the respective bit in GSCPERSTATEN, so that the missing acknowledge is not taken into account.*

*Note: When a GSC mode request has been successfully entered, the GSC arbiter is open for any new request. In case a request occurs to enter the current mode, this request is pipelined and remains pending.*

*It is recommended to request a command by a software trigger. In particular the clock-off command should be triggered by SW2. The usage of commands requested by hardware has to be done carefully. Only hardware resources requesting Normal Mode should be selected. If the software has detected a wake-up then pending mode change requests can be removed by clearing the bits of the selected sources in **GSCEN** and then enabling the bits in **GSCEN** again.*

### 8.7.1.4 Terminating a Request Trigger

A request trigger is no longer taken into account for the arbitration after the de-assertion of the request trigger, if it is not enabled or when its respective enable bit is cleared.

### 8.7.1.5 Suspend Control Flow

The suspend feature is controlled by the OCDS block. The GSC operates only as control and communication interface towards the system. The suspend feature is composed out of two requirements:

The mode that has to be entered when the Suspend Mode is requested.

The mode that has to be entered when the Suspend Mode is left.

## System Control Unit (SCU)

The request to enter Suspend Mode is forwarded from the OCDS. When the Suspend Mode is requested the system is expected to be stopped as soon as possible in an idle state where no internal process is pending and in a way that this system state does not lead to any damage internally or externally and can also be left without any damage. Therefore all peripherals in the system are requested to enter a mode where the clock can be stopped. This is done by sending a debug command.

Leaving the Suspend Mode should serve the goal that debugging is a non-intrusive operation. Therefore leaving the Suspend Mode can not lead to only one dedicated system mode, instead it leads to the system mode the system left when it was requested to exit the Suspend Mode. The system mode is stored when a Suspend Mode request is detected by the GSC and is used as target system mode when a leave Suspend Mode trigger is detected by the GSC.

### 8.7.1.6 Error Feedback for a Mode Transition

In case at least one peripheral reports an error the error flag in register GSCSTAT is set. If no error is currently detected upon a new assertion of a system mode by the GSC the error flag is cleared. To inform the system of this erroneous state an interrupt can be generated.

## 8.7.2 GSC Registers

### 8.7.2.1 GSC Control and Status Registers

The following register control and configure the behavior of the GSC.

#### GSCSWREQ

##### GSC Software Request Register



| Field         | Bits   | Type | Description                                                                                                                                                                                                                                    |
|---------------|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>SWTRG1</b> | 0      | rwh  | <b>Software Trigger 1 (SW1)</b><br>$0_B$ No SW1 request trigger is generated<br>$1_B$ A SW1 request trigger is generated<br>This bit is automatically cleared if the SW1 request trigger wins the arbitration and was broadcast to the system. |
| <b>SWTRG2</b> | 1      | rwh  | <b>Software Trigger 2 (SW2)</b><br>$0_B$ No SW2 request trigger is generated<br>$1_B$ A SW2 request trigger is generated<br>This bit is automatically cleared if the SW2 request trigger wins the arbitration and was broadcast to the system. |
| <b>0</b>      | [15:2] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                        |

## System Control Unit (SCU)

**GSCEN**
**GSC Enable Register**
**SFR (FF16<sub>H</sub>/8B<sub>H</sub>)**
**Reset Value: 7FFF<sub>H</sub>**

| 15 | 14               | 13       | 12        | 11        | 10        | 9         | 8         | 7              | 6              | 5              | 4                | 3 | 2 | 1 | 0    |
|----|------------------|----------|-----------|-----------|-----------|-----------|-----------|----------------|----------------|----------------|------------------|---|---|---|------|
| 0  | OCD<br>SEN<br>EN | RES<br>1 | SW2<br>EN | SW1<br>EN | GPT<br>EN | ITC<br>EN | WUT<br>EN | ESR<br>2<br>EN | ESR<br>1<br>EN | ESR<br>0<br>EN | OCD<br>SEX<br>EN |   |   |   | RES0 |

| Field           | Bits  | Type | Description                                                                                                                                                                                          |
|-----------------|-------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>RES0</b>     | [3:0] | rw   | <b>Reserved</b><br>Must be written with 0000 <sub>B</sub> .                                                                                                                                          |
| <b>OCDSEXEN</b> | 4     | rw   | <b>OCDS Exit Request Trigger Enable</b><br>0 <sub>B</sub> OCDS exit request trigger is not taken into account (disabled)<br>1 <sub>B</sub> OCDS exit request trigger is taken into account (enabled) |
| <b>ESR0EN</b>   | 5     | rw   | <b>ESR0 Request Trigger Enable</b><br>0 <sub>B</sub> ESR0 request trigger is not taken into account (disabled)<br>1 <sub>B</sub> ESR0 request trigger is taken into account (enabled)                |
| <b>ESR1EN</b>   | 6     | rw   | <b>ESR1 Request Trigger Enable</b><br>0 <sub>B</sub> ESR1 request trigger is not taken into account (disabled)<br>1 <sub>B</sub> ESR1 request trigger is taken into account (enabled)                |
| <b>ESR2EN</b>   | 7     | rw   | <b>ESR2 Request Trigger Enable</b><br>0 <sub>B</sub> ESR2 request trigger is not taken into account (disabled)<br>1 <sub>B</sub> ESR2 request trigger is taken into account (enabled)                |
| <b>WUTEN</b>    | 8     | rw   | <b>WUT Request Trigger Enable</b><br>0 <sub>B</sub> WUT request trigger is not taken into account (disabled)<br>1 <sub>B</sub> WUT request trigger is taken into account (enabled)                   |

## System Control Unit (SCU)

| Field           | Bits | Type | Description                                                                                                                                                                                                                                                                                 |
|-----------------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ITCEN</b>    | 9    | rw   | <b>ITC Request Trigger Enable</b><br>0 <sub>B</sub> ITC request trigger is not taken into account (disabled)<br>1 <sub>B</sub> ITC request trigger is taken into account (enabled)                                                                                                          |
| <b>GPTEN</b>    | 10   | rw   | <b>GTP12E Request Trigger Enable</b><br>0 <sub>B</sub> GPT12E request trigger is not taken into account (disabled)<br>1 <sub>B</sub> GPT12E request trigger is taken into account (enabled)                                                                                                 |
| <b>SW1EN</b>    | 11   | rw   | <b>Software 1 Request Trigger Enable</b><br>0 <sub>B</sub> SW1 request trigger is not taken into account (disabled)<br>1 <sub>B</sub> SW1 request trigger is taken into account (enabled)                                                                                                   |
| <b>SW2EN</b>    | 12   | rw   | <b>Software 2 Request Trigger Enable</b><br>0 <sub>B</sub> SW2 request trigger is not taken into account (disabled)<br>1 <sub>B</sub> SW2 request trigger is taken into account (enabled)                                                                                                   |
| <b>RES1</b>     | 13   | rw   | <b>Reserved</b><br>Read as 1 after reset; returns the value that is written.                                                                                                                                                                                                                |
| <b>OCDSENEN</b> | 14   | rw   | <b>OCDS Entry Request Trigger Enable</b><br>0 <sub>B</sub> OCDS entry request trigger is not taken into account (disabled)<br>1 <sub>B</sub> OCDS entry request trigger is taken into account (enabled)<br>OCDS entry is the request source belonging to the according connector interface. |
| <b>0</b>        | 15   | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                     |

## System Control Unit (SCU)

**GSCSTAT**
**GSC Status Register**
**SFR (FF18<sub>H</sub>/8C<sub>H</sub>)**
**Reset Value: 3C00<sub>H</sub>**

|    |    |    |    |    |    |     |     |   |   |      |   |   |   |         |   |
|----|----|----|----|----|----|-----|-----|---|---|------|---|---|---|---------|---|
| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7 | 6 | 5    | 4 | 3 | 2 | 1       | 0 |
| 0  |    |    |    |    |    | PEN | ERR | 0 |   | NEXT |   | 0 |   | CURRENT |   |

r                    rh                    rh                    rh                    r                    rh                    r                    rh

| Field          | Bits  | Type | Description                                                                                                                                                                                                                        |
|----------------|-------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>CURRENT</b> | [1:0] | rh   | <b>Currently used Command</b><br>This bit field states the currently used system mode.                                                                                                                                             |
| <b>NEXT</b>    | [5:4] | rh   | <b>Next to use Command</b><br>This bit field states the next to be used system mode.                                                                                                                                               |
| <b>ERR</b>     | 8     | rh   | <b>Error Status Flag</b><br>This bit flags if with the last command that was broadcast was acknowledge with at least one error.<br>This bit is automatically cleared when a new command is broadcast.                              |
| <b>PEN</b>     | 9     | rh   | <b>Command Pending Flag</b><br>This flag states if currently a command is pending or not. A command is pending after the broadcast as long as no all blocks acknowledge that they finished the operation requested by the command. |

## System Control Unit (SCU)

| Field  | Bits                        | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|-----------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SOURCE | [13:10]                     | rh   | <b>Requesting Source Status</b><br>This bit field monitors the source that triggered the last request.<br>0000 <sub>B</sub> Reserved<br>0001 <sub>B</sub> Reserved<br>0010 <sub>B</sub> Reserved<br>0011 <sub>B</sub> Reserved<br>0100 <sub>B</sub> OCDS exit<br><u>0101<sub>B</sub> ESR0</u><br><u>0110<sub>B</sub> ESR1</u><br><u>0111<sub>B</sub> ESR2</u><br>1000 <sub>B</sub> WUT<br>1001 <sub>B</sub> ITC<br>1010 <sub>B</sub> GPT12E<br>1011 <sub>B</sub> SW1<br>1100 <sub>B</sub> SW2<br>1101 <sub>B</sub> Reserved, do not use this combination<br>1110 <sub>B</sub> OCDS entry<br>1111 <sub>B</sub> Reserved, do not use this combination |
| 0      | [3:2],<br>[7:6],<br>[15:14] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

## System Control Unit (SCU)

**GSCPSTATEN**
**GSC Peripheral Status Enable Register**

 SFR (FF04<sub>H</sub>/82<sub>H</sub>)

 Reset Value: FFFF<sub>H</sub>

| 15                | 14                | 13                | 12                | 11                | 10                | 9                 | 8                 | 7                 | 6                 | 5                 | 4                 | 3                 | 2                 | 1                 | 0                 |
|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|
| <b>USIC 3</b>     | <b>USIC 2</b>     | <b>USIC 1</b>     | <b>USIC 0</b>     | <b>FL</b>         | <b>MEM</b>        | <b>RTC</b>        | <b>CCU 63</b>     | <b>CCU 62</b>     | <b>CCU 61</b>     | <b>CCU 60</b>     | <b>M CAN</b>      | <b>CC2</b>        | <b>RES 0</b>      | <b>GPT 12E</b>    | <b>ADC</b>        |
| <small>rw</small> |

| Field         | Bits | Type              | Description                                                                                                                                                                                                                                                                                              |
|---------------|------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ADC</b>    | 0    | <small>rw</small> | <b>ADC Acknowledge Enable</b><br>This bit defines if the acknowledge status of ADC modules is taken into account and displayed or ignored.<br><br>0 <sub>B</sub> The ADC modules acknowledge is ignored, it is treated as always asserted<br>1 <sub>B</sub> The ADC modules acknowledge is used          |
| <b>GPT12E</b> | 1    | <small>rw</small> | <b>GPT12E Acknowledge Enable</b><br>This bit defines if the acknowledge status of GPT12E module is taken into account and displayed or ignored.<br><br>0 <sub>B</sub> The GPT12E module acknowledge is ignored, it is treated as always asserted<br>1 <sub>B</sub> The GPT12E module acknowledge is used |
| <b>RES0</b>   | 2    | <small>rw</small> | <b>Reserved</b><br>Must be written with 0 <sub>B</sub> .                                                                                                                                                                                                                                                 |
| <b>CC2</b>    | 3    | <small>rw</small> | <b>CC2 Acknowledge Enable</b><br>This bit defines if the acknowledge status of CC2 module is taken into account and displayed or ignored.<br><br>0 <sub>B</sub> The CC2 module acknowledge is ignored, it is treated as always asserted<br>1 <sub>B</sub> The CC2 module acknowledge is used             |

## System Control Unit (SCU)

| Field        | Bits | Type | Description                                                                                                                                                                                                                                                                                                  |
|--------------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>MCAN</b>  | 4    | rw   | <b>MultiCAN Acknowledge Enable</b><br>This bit defines if the acknowledge status of MultiCAN module is taken into account and displayed or ignored.<br>0 <sub>B</sub> The MultiCAN module acknowledge is ignored, it is treated as always asserted<br>1 <sub>B</sub> The MultiCAN module acknowledge is used |
| <b>CCU60</b> | 5    | rw   | <b>CCU60 Acknowledge Enable</b><br>This bit defines if the acknowledge status of CCU60 module is taken into account and displayed or ignored.<br>0 <sub>B</sub> The CCU60 module acknowledge is ignored, it is treated as always asserted<br>1 <sub>B</sub> The CCU60 module acknowledge is used             |
| <b>CCU61</b> | 6    | rw   | <b>CCU61 Acknowledge Enable</b><br>This bit defines if the acknowledge status of CCU61 module is taken into account and displayed or ignored.<br>0 <sub>B</sub> The CCU61 module acknowledge is ignored, it is treated as always asserted<br>1 <sub>B</sub> The CCU61 module acknowledge is used             |
| <b>CCU62</b> | 7    | rw   | <b>CCU62 Acknowledge Enable</b><br>This bit defines if the acknowledge status of CCU62 module is taken into account and displayed or ignored.<br>0 <sub>B</sub> The CCU62 module acknowledge is ignored, it is treated as always asserted<br>1 <sub>B</sub> The CCU62 module acknowledge is used             |
| <b>CCU63</b> | 8    | rw   | <b>CCU63 Acknowledge Enable</b><br>This bit defines if the acknowledge status of CCU63 module is taken into account and displayed or ignored.<br>0 <sub>B</sub> The CCU63 module acknowledge is ignored, it is treated as always asserted<br>1 <sub>B</sub> The CCU63 module acknowledge is used             |

**System Control Unit (SCU)**

| <b>Field</b> | <b>Bits</b> | <b>Type</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                            |
|--------------|-------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>RTC</b>   | 9           | rw          | <p><b>RTC Acknowledge Enable</b><br/>           This bit defines if the acknowledge status of RTC module is taken into account and displayed or ignored.</p> <p><math>0_B</math> The RTC module acknowledge is ignored, it is treated as always asserted<br/> <math>1_B</math> The RTC module acknowledge is used</p>                                                         |
| <b>MEM</b>   | 10          | rw          | <p><b>C166SV2 Subsystem Acknowledge Enable</b><br/>           This bit defines if the acknowledge status of C166SV2 Subsystem module is taken into account and displayed or ignored.</p> <p><math>0_B</math> The C166SV2 Subsystem module acknowledge is ignored, it is treated as always asserted<br/> <math>1_B</math> The C166SV2 Subsystem module acknowledge is used</p> |
| <b>FL</b>    | 11          | rw          | <p><b>Flash Acknowledge Enable</b><br/>           This bit defines if the acknowledge status of Flash module is taken into account and displayed or ignored.</p> <p><math>0_B</math> The Flash module acknowledge is ignored, it is treated as always asserted<br/> <math>1_B</math> The Flash module acknowledge is used</p>                                                 |
| <b>USIC0</b> | 12          | rw          | <p><b>USIC0 Acknowledge Enable</b><br/>           This bit defines if the acknowledge status of USIC0 module is taken into account and displayed or ignored.</p> <p><math>0_B</math> The USIC0 module acknowledge is ignored, it is treated as always asserted<br/> <math>1_B</math> The USIC0 module acknowledge is used</p>                                                 |
| <b>USIC1</b> | 13          | rw          | <p><b>USIC1 Acknowledge Enable</b><br/>           This bit defines if the acknowledge status of USIC1 module is taken into account and displayed or ignored.</p> <p><math>0_B</math> The USIC1 module acknowledge is ignored, it is treated as always asserted<br/> <math>1_B</math> The USIC1 module acknowledge is used</p>                                                 |

System Control Unit (SCU)

| <b>Field</b> | <b>Bits</b> | <b>Type</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                |
|--------------|-------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>USIC2</b> | 14          | rw          | <p><b>USIC2 Acknowledge Enable</b><br/>           This bit defines if the acknowledge status of USIC2 module is taken into account and displayed or ignored.</p> <p>0<sub>B</sub> The USIC2 module acknowledge is ignored, it is treated as always asserted<br/>           1<sub>B</sub> The USIC2 module acknowledge is used</p> |
| <b>USIC3</b> | 15          | rw          | <p><b>USIC3 Acknowledge Enable</b><br/>           This bit defines if the acknowledge status of USIC3 module is taken into account and displayed or ignored.</p> <p>0<sub>B</sub> The USIC3 module acknowledge is ignored, it is treated as always asserted<br/>           1<sub>B</sub> The USIC3 module acknowledge is used</p> |

## System Control Unit (SCU)

**GSCPSTAT**
**GSC Peripheral Status Register**
**SFR (FF1A<sub>H</sub>/8D<sub>H</sub>)**
**Reset Value: FFFF<sub>H</sub>**

| 15            | 14            | 13            | 12            | 11        | 10         | 9          | 8             | 7             | 6             | 5             | 4            | 3          | 2        | 1              | 0          |
|---------------|---------------|---------------|---------------|-----------|------------|------------|---------------|---------------|---------------|---------------|--------------|------------|----------|----------------|------------|
| <b>USIC 3</b> | <b>USIC 2</b> | <b>USIC 1</b> | <b>USIC 0</b> | <b>FL</b> | <b>MEM</b> | <b>RTC</b> | <b>CCU 63</b> | <b>CCU 62</b> | <b>CCU 61</b> | <b>CCU 60</b> | <b>M CAN</b> | <b>CC2</b> | <b>1</b> | <b>GPT 12E</b> | <b>ADC</b> |
| rh            | rh            | rh            | rh            | rh        | rh         | rh         | rh            | rh            | rh            | rh            | rh           | rh         | r        | rh             | rh         |

| Field         | Bits | Type | Description                                                                                                                                                                                                                                                                                                                                                           |
|---------------|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ADC</b>    | 0    | rh   | <p><b>ADC Acknowledge Status</b><br/>                     This bit shows the acknowledge status of the modules ADC.</p> <p>0<sub>B</sub> The modules ADC change currently their kernel state. Their acknowledge has not been received.</p> <p>1<sub>B</sub> Acknowledge of the modules ADC is taken into account and has been received or is not relevant.</p>        |
| <b>GPT12E</b> | 1    | rh   | <p><b>GPT12E Acknowledge Status</b><br/>                     This bit shows the acknowledge status of the modules GPT12E.</p> <p>0<sub>B</sub> The module GPT12E changes currently its kernel state. Its acknowledge has not been received.</p> <p>1<sub>B</sub> Acknowledge of the module GPT12E is taken into account and has been received or is not relevant.</p> |
| <b>CC2</b>    | 3    | rh   | <p><b>CC2 Acknowledge Status</b><br/>                     This bit shows the acknowledge status of the module CC2.</p> <p>0<sub>B</sub> The module CC2 changes currently its kernel state. Its acknowledge has not been received.</p> <p>1<sub>B</sub> Acknowledge of the module CC2 is taken into account and has been received or is not relevant.</p>              |

System Control Unit (SCU)

| <b>Field</b> | <b>Bits</b> | <b>Type</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                       |
|--------------|-------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>MCAN</b>  | 4           | rh          | <p><b>MultiCAN Acknowledge Status</b><br/>           This bit shows the acknowledge status of the module MultiCAN.</p> <p><math>0_B</math> The module MultiCAN changes currently its kernel state. Its acknowledge has not been received.</p> <p><math>1_B</math> Acknowledge of the module MultiCAN is taken into account and has been received or is not relevant.</p> |
| <b>CCU60</b> | 5           | rh          | <p><b>CCU60 Acknowledge Status</b><br/>           This bit shows the acknowledge status of the module CCU60.</p> <p><math>0_B</math> The module CCU60 changes currently its kernel state. Its acknowledge has not been received.</p> <p><math>1_B</math> Acknowledge of the module CCU60 is taken into account and has been received or is not relevant.</p>             |
| <b>CCU61</b> | 6           | rh          | <p><b>CCU61 Acknowledge Status</b><br/>           This bit shows the acknowledge status of the module CCU61.</p> <p><math>0_B</math> The module CCU61 changes currently its kernel state. Its acknowledge has not been received.</p> <p><math>1_B</math> Acknowledge of the module CCU61 is taken into account and has been received or is not relevant.</p>             |
| <b>CCU62</b> | 7           | rh          | <p><b>CCU62 Acknowledge Status</b><br/>           This bit shows the acknowledge status of the module CCU62.</p> <p><math>0_B</math> The module CCU62 changes currently its kernel state. Its acknowledge has not been received.</p> <p><math>1_B</math> Acknowledge of the module CCU62 is taken into account and has been received or is not relevant.</p>             |

**System Control Unit (SCU)**

| <b>Field</b> | <b>Bits</b> | <b>Type</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------|-------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>CCU63</b> | 8           | rh          | <p><b>CCU63 Acknowledge Status</b><br/>           This bit shows the acknowledge status of the module CCU63.</p> <p><math>0_B</math> The module CCU63 changes currently its kernel state. Its acknowledge has not been received.</p> <p><math>1_B</math> Acknowledge of the module CCU63 is taken into account and has been received or is not relevant.</p>                                                 |
| <b>RTC</b>   | 9           | rh          | <p><b>RTC Acknowledge Status</b><br/>           This bit shows the acknowledge status of the module RTC.</p> <p><math>0_B</math> The module RTC changes currently its kernel state. Its acknowledge has not been received.</p> <p><math>1_B</math> Acknowledge of the module RTC is taken into account and has been received or is not relevant.</p>                                                         |
| <b>MEM</b>   | 10          | rh          | <p><b>C166SV2 Subsystem Acknowledge Status</b><br/>           This bit shows the acknowledge status of the module C166SV2 Subsystem.</p> <p><math>0_B</math> The module C166SV2 Subsystem changes currently its kernel state. Its acknowledge has not been received.</p> <p><math>1_B</math> Acknowledge of the module C166SV2 Subsystem is taken into account and has been received or is not relevant.</p> |
| <b>FL</b>    | 11          | rh          | <p><b>Flash Acknowledge Status</b><br/>           This bit shows the acknowledge status of the module Flash.</p> <p><math>0_B</math> The module Flash changes currently its kernel state. Its acknowledge has not been received.</p> <p><math>1_B</math> Acknowledge of the module Flash is taken into account and has been received or is not relevant.</p>                                                 |

System Control Unit (SCU)

| <b>Field</b> | <b>Bits</b> | <b>Type</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                   |
|--------------|-------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>USIC0</b> | 12          | rh          | <p><b>USIC0 Acknowledge Status</b></p> <p>This bit shows the acknowledge status of the module USIC0.</p> <p><math>0_B</math> The module USIC0 changes currently its kernel state. Its acknowledge has not been received.</p> <p><math>1_B</math> Acknowledge of the module USIC0 is taken into account and has been received or is not relevant.</p> |
| <b>USIC1</b> | 13          | rh          | <p><b>USIC1 Acknowledge Status</b></p> <p>This bit shows the acknowledge status of the module USIC1.</p> <p><math>0_B</math> The module USIC1 changes currently its kernel state. Its acknowledge has not been received.</p> <p><math>1_B</math> Acknowledge of the module USIC1 is taken into account and has been received or is not relevant.</p> |
| <b>USIC2</b> | 14          | rh          | <p><b>USIC2 Acknowledge Status</b></p> <p>This bit shows the acknowledge status of the module USIC2.</p> <p><math>0_B</math> The module USIC2 changes currently its kernel state. Its acknowledge has not been received.</p> <p><math>1_B</math> Acknowledge of the module USIC2 is taken into account and has been received or is not relevant.</p> |
| <b>USIC3</b> | 15          | rh          | <p><b>USIC3 Acknowledge Status</b></p> <p>This bit shows the acknowledge status of the module USIC3.</p> <p><math>0_B</math> The module USIC3 changes currently its kernel state. Its acknowledge has not been received.</p> <p><math>1_B</math> Acknowledge of the module USIC3 is taken into account and has been received or is not relevant.</p> |
| <b>1</b>     | 2           | r           | <p><b>Reserved</b><br/>Read as 1</p>                                                                                                                                                                                                                                                                                                                 |

### **System Control Unit (SCU)**

The acknowledge status bit is set, if acknowledge of the module x is taken into account and has been received or is not relevant. The acknowledge of the module x is not relevant if the acknowledge of the module x is not taken into account or the module x currently does not undergo a change of kernel state mode. In these cases the acknowledge is assumed to be received.

## 8.8 Software Boot Support

In order to determine the correct starting point of operation for the software a minimum of hardware support is required. As much as possible is done via software. Some decisions have to be done in hardware because they must be known before any software is operational.

### **8.8.1 Start-up Registers**

### **8.8.1.1 Start-up Status Register**

Register STSTAT contains the information required by the boot software to identify the different start-up settings that can be selected.

STSTAT

## **Start-up Status Register**

MEM (F1E0<sub>H</sub>/--)

**Reset Value: 8000<sub>H</sub>**

HWCFG

| Field        | Bits   | Type | Description                                                                                                                                                                                                                                                          |
|--------------|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>HWCFG</b> | [7:0]  | rh   | <p><b>Hardware Configuration Setting</b></p> <p>This bit field contains the value that is used by the boot software.</p> <p>This bit field is updated in case of an Application Reset with the content by register SWRSTCON.SWCFG if bit SWRSTCON.SWBOOT is set.</p> |
| <b>0</b>     | [14:8] | r    | <p><b>Reserved</b></p> <p>Read as 0; should be written with 0.</p>                                                                                                                                                                                                   |
| <b>1</b>     | 15     | r    | <p><b>Reserved</b></p> <p>Read as 1; should be written with 1.</p>                                                                                                                                                                                                   |

## System Control Unit (SCU)

## 8.9 External Request Unit (ERU)

The External Request Unit (ERU) is a versatile event and pattern detection unit. Its major task is the **generation of interrupts based on selectable trigger events at different inputs**, e.g. to generate external interrupt requests if an edge occurs at an input pin.

The detected events can also be used by other modules to trigger or to gate module-specific actions, such as conversions of the ADC module.

### 8.9.1 Introduction

The ERU of the XC27x5X can be split in three main functional parts:

- 4 independent **Input Channels x** for input selection and conditioning of trigger or gating functions
- Event distribution: A **Connecting Matrix** defines the events of the Input Channel x that lead to a reaction of an Output Channel y.
- 4 independent **Output Channels y** for combination of events, definition of their effects and distribution to the system (interrupt generation, ADC conversion triggers)



**Figure 8-23 External Request Unit Overview**

These tasks are handled by the following building blocks:

- An **External Request Select Unit (ERSx)** per Input Channel allows the selection of one out of two or a logical combination of two input signals (ERU\_xA, ERU\_xB) to a

## System Control Unit (SCU)

common trigger. For each of these two signals, an input vector of 4 possible inputs is available (e.g. the actual input ERU\_xA can be selected from one of the ERU inputs ERU\_xA[3:0], similar for ERU\_xB).

- An **Event Trigger Logic (ETLx)** per Input Channel allows the definition of the transition (edge selection, or by software) that lead to a trigger event and can also store this status. Here, the input levels of the selected signals are translated into events (event detected = event flag becomes set, independent of the polarity of the original input signals).
- The **Connecting Matrix** distributes the events and status flags generated by the Input Channels to the Output Channels. Additionally, some Peripheral Trigger signals from other modules (e.g. CC2) are made available and can be combined with the triggers generated by the Input Channels of the ERU.
- An **Output Gating Unit (OGUy)** per Output Channel that combines the available trigger events and status information from the Input Channels. An event of one Input Channel can lead to reactions of several Output Channels, or also events of several Input Channels can be combined to a reaction of one Output Channel (pattern detection).

Different types of reactions are possible, e.g. interrupt generation (based on signals ERU\_IOUTy), triggering of ADC conversions (based on signals ERU\_TOUTy), or gating of ADC conversions (based on signals ERU\_GOUTy).

The ERU is controlled by a number of registers, shown in [Figure 8-24](#), and described in [Section 8.9.8](#).



**Figure 8-24 ERU Registers Overview**

### 8.9.2 ERU Input Connections

The inputs to the ERU can be selected from a large number of input signals. While some of the inputs come directly from a pin, other inputs use signals from various peripheral modules, such as the USIC (signals named with prefix UxCy to indicate the communication channel) and the MultiCAN modules. These signals are input signals from the pin that has been selected as input for a USIC or MultiCAN function. The selection of the input is made within the respective USIC or MultiCAN module.

In the ERU input connections are described in [Section 8.18.3.1](#).

Usually, such signals would be selected for an ERU function when the input function to the USIC or MultiCAN module is not used otherwise, or the module is not used at all. However, it is also possible to select a input which is actually needed in a USIC or MultiCAN module, and to use it also in the ERU to provide a certain trigger functions, eventually combined with other signals (e.g. to generate an interrupt trigger in case a start of frame is detected at a selected communication).

With this structure, the number of possible input pins is significantly increased, because not only the selection capability of the ERU is used, but also the selection capability of the communication modules.

*Note: All functional inputs of the ERU are synchronized to  $f_{SYS}$  before they can affect the internal logic. The resulting delay of  $2/f_{SYS}$  and an uncertainty of  $1/f_{SYS}$  have to be taken into account for precise timing calculation.*

*An edge of an input can only be correctly detected if both, the high phase and the low phase of the input are each longer than  $1/f_{SYS}$ .*

## System Control Unit (SCU)

### 8.9.3 External Request Select Unit (ERSx)

For each Input Channel x ( $x = 0-3$ ), an ERSx unit handles the input selection for the associated ETLx unit. Each ERSx performs a logical combination of two signals (Ax, Bx) to provide one combined output ERSxO to the associated ETLx. Input Ax can be selected from 4 options of the input vector ERU\_xA[3:0] and can be optionally inverted. A similar structure exists for input Bx (selection from ERU\_xB[3:0]).

In addition to the direct choice of either input Ax or Bx or their inverted values, the possible logical combinations for two selected inputs are a logical AND or a logical OR.



Figure 8-25 External Request Select Unit Overview

The ERS units are controlled via register **EXISEL** (one register for all four ERSx units) and registers EXICONx (one register for each ERSx and associated ETLx unit, e.g. **EXICON0** for Input Channel 0).

## System Control Unit (SCU)

### 8.9.4 Event Trigger Logic (ETLx)

For each Input Channel x (x = 0-3), an event trigger logic ETLx derives a trigger event and a status from the input ERUxO delivered by the associated ERSx unit. Each ETLx is based on an edge detection block, where the detection of a rising or a falling edge can be individually enabled. Both edges lead to a trigger event if both enable bits are set (e.g. to handle a toggling input).

Each of the four ETLx units has an associated EXICONx register, that controls all options of an ETLx (the register also holds control bits for the associated ERSx unit, e.g. **EXICON0** to control ESR0 and ETL0).



**Figure 8-26 Event Trigger Logic Overview**

When the selected event (edge) is detected, the status flag EXICONx.FL becomes set. This flag can also be modified by software (set or clear). Two different operating modes are supported by this status flag.

It can be used as “sticky” flag, that is set by hardware when the desired event has been detected and has to be cleared by software. In this operating mode, it indicates that the event has taken place, but without indicating the actual status of the input.

In the second operating mode, it is cleared automatically if the “opposite” event is detected. For example, if only the falling edge detection is enabled to set the status flag, it is cleared when the rising edge is detected. In this mode, it can be used for pattern

## System Control Unit (SCU)

detection where the actual status of the input is important (enabling both edge detections is not useful in this mode).

The output of the status flag is connected to all following Output Gating Units (OGUy) in parallel (see [Figure 8-27](#)) to provide **pattern detection capability of all OGUy units** based on different or the same status flags.

In addition to the modification of the status flag, a trigger pulse output TRxy of ETLx can be enabled (by bit EXICONx.PE) and selected to **trigger actions in one of the OGUy units**. The target OGUy for the trigger is selected by bit field EXICON.OCS.

The trigger becomes active when the selected edge event is detected, independently from the status flag EXICONx.FL.

## System Control Unit (SCU)

## 8.9.5 Connecting Matrix

The connecting matrix distributes the trigger signals (TRxy) and status signals (EXICONx.FL) from the different ETLx units between the OGUy units. In addition, it receives peripheral trigger signals that can be OR-combined with the ETLx trigger signals in the OGUy units. **Figure 8-27** provides a complete overview of the connections between the ETLx and the OGUy units.



Figure 8-27 Connecting Matrix between ETLx and OGUy

### 8.9.6 Output Gating Unit (OGUy)

Each OGU $y$  ( $y = 0\text{-}3$ ) unit combines the available trigger events and status flags from the Input Channels and distributes the results to the system. **Figure 8-28** illustrates the logic blocks within an OGU $y$  unit. All functions of an OGU $y$  unit are controlled by its associated EXOCO $Ny$  register, e.g. **EXOCO $0$**  for OGU0. The function of an OGU $y$  unit can be split into two parts:

- Trigger combination (see [Section 8.9.6.1](#)):

All trigger signals TRxy from the Input Channels that are enabled and directed to OGUy, a selected peripheral-related trigger event, and a pattern change event (if enabled) are logically OR-combined.

- **Pattern detection** (see [Section 8.9.6.2](#)):

The status flags EXICONx.FL of the Input Channels can be enabled to take part in the pattern detection. A pattern match is detected while all enabled status flags are set.



**Figure 8-28** Output Gating Unit for Output Channel y

## System Control Unit (SCU)

Each OGUy unit generates 4 output signals that are distributed to the system (not all of them are necessarily used, please refer to [Section 8.9.7](#)):

- **ERU\_PDOUTy** to directly output the pattern match information for gating purposes in other modules (pattern match = 1).
- **ERU\_GOUTy** to output the pattern match or pattern miss information (inverted pattern match), or a permanent 0 or 1 under software control for gating purposes in other modules.
- **ERU\_TOUTy** as combination of a peripheral trigger, a pattern detection result change event, or the ETLx trigger outputs TRxy to trigger actions in other modules.
- **ERU\_IOUTy** as gated trigger output (ERU\_GOUTy logical AND-combined with ERU\_TOUTy) to trigger interrupts (e.g. the interrupt generation can be gated to allow interrupt activation during a certain time window).

### 8.9.6.1 Trigger Combination

The trigger combination logically OR-combines different trigger inputs to form a common trigger ERU\_TOUTy. Possible trigger inputs are:

- In each ETLx unit of the **Input Channels**, the trigger output TRxy can be enabled and the trigger event can be directed to one of the OGUy units.
- One out of three **peripheral trigger** signals per OGUy can be selected as additional trigger source. These peripheral triggers are generated by on-chip peripheral modules, such as capture/compare or timer units. The selection is done by bit field EXOCONy.ISS.
- In the case that at least one **pattern detection** input is enabled (EXOCONy.IPENx) and a change of the pattern detection result from pattern match to pattern miss (or vice-versa) is detected, a trigger event is generated to indicate a pattern detection result event (if enabled by ECOCOCONy.GEEN).

The trigger combination offers the possibility to program different trigger criteria for several input signals (independently for each Input Channel) or peripheral signals, and to combine their effects to a single output, e.g. to generate an interrupt or to start an ADC conversion. This combination capability allows the generation of an interrupt per OGU that can be triggered by several inputs (multitude of request sources -> one reaction).

[Section 8.18.3.2](#) describes the peripheral trigger connections for the OGUy stages.

The selection is defined by the bit fields ISS in registers **EXOCON0** (for OGU0), **EXOCON1** (for OGU1), **EXOCON2** (for OGU2), or **EXOCON3** (for OGU3).

### 8.9.6.2 Pattern Detection

The pattern detection logic allows the combination of the status flags of all ETLx units. Each status flag can be individually included or excluded from the pattern detection for each OGUy, via control bits EXOCONy.IPENx. The pattern detection block outputs the following pattern detection results:

## System Control Unit (SCU)

- **Pattern match** (EXOCONy.PDR = 1 and ERU\_PDOUTy = 1):  
A pattern match is indicated while all status flags FL that are included in the pattern detection are 1.
- **Pattern miss** (EXOCONy.PDR = 0 and ERU\_PDOUTy = 0):  
A pattern miss is indicated while at least one of the status flags FL that are included in the pattern detection is 0.

In addition, the pattern detection can deliver a trigger event if the pattern detection result changes from match to miss or vice-versa (if enabled by EXOCONy.GEEN = 1). The pattern result change event is logically OR-combined with the other enabled trigger events to support interrupt generation or to trigger other module functions (e.g. in the ADC). The event is indicated when the pattern detection result changes and EXOCONy.PDR becomes updated.

The interrupt generation in the OGUy is based on the trigger ERU\_TOUTy that can be gated (masked) with the pattern detection result ERU\_PDOUTy. This allows an automatic and reproducible generation of interrupts during a certain time window, where the request event is elaborated by the trigger combination block and the time window information (gating) is given by the pattern detection. For example, interrupts can be issued on a regular time base (peripheral trigger input from capture/compare unit is selected) while a combination of input signals occurs (pattern detection based on ETLx status bits).

A programmable gating scheme introduces flexibility to adapt to application requirements and allows the generation of interrupt requests ERU\_IOUTy under different conditions:

- **Pattern match** (EXOCONy.GP = 10<sub>B</sub>):  
An interrupt request is issued when a trigger event occurs while the pattern detection shows a pattern match.
- **Pattern miss** (EXOCONy.GP = 11<sub>B</sub>):  
An interrupt request is issued when the trigger event occurs while the pattern detection shows a pattern miss.
- **Independent** of pattern detection (EXOCONy.GP = 01<sub>B</sub>):  
In this mode, each occurring trigger event leads to an interrupt request. The pattern detection output can be used independently from the trigger combination for gating purposes of other peripherals (independent use of ERU\_TOUTy and ERU\_PDOUTy with interrupt requests on trigger events).
- **No interrupts** (EXOCONy.GP = 00<sub>B</sub>, default setting)  
In this mode, an occurring trigger event does not lead to an interrupt request. The pattern detection output can be used independently from the trigger combination for gating purposes of other peripherals (independent use of ERU\_TOUTy and ERU\_PDOUTy without interrupt requests on trigger events).

### 8.9.7 ERU Output Connections

**Section 8.18.3.3** describes the connections of the ERU output signals for gating or triggering other module functions, as well as the connections to the interrupt control registers.

## 8.9.8 ERU Registers

### 8.9.8.1 External Input Selection Register EXISEL

This register selects the A and B inputs for all four ERS units. The possible input signals are given in [Table 8-19](#).

#### EXISEL

**External Input Select Register ESFR (F1A0<sub>H</sub>/D0<sub>H</sub>)** **Reset Value: 0000<sub>H</sub>**

| 15    | 14    | 13    | 12    | 11    | 10    | 9     | 8     | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-------|-------|-------|-------|-------|-------|-------|---|---|---|---|---|---|---|---|
| EXS3B | EXS3A | EXS2B | EXS2A | EXS1B | EXS1A | EXS0B | EXS0A |   |   |   |   |   |   |   |   |

rw                    rw

| Field        | Bits  | Type | Description                                                                                                                                                                                                                                                                                   |
|--------------|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>EXS0A</b> | [1:0] | rw   | <b>External Source Select for A0 (ERS0)</b><br>This bit field defines which input is selected for A0.<br><br>00 <sub>B</sub> Input ERU_0A0 is selected<br>01 <sub>B</sub> Input ERU_0A1 is selected<br>10 <sub>B</sub> Input ERU_0A2 is selected<br>11 <sub>B</sub> Input ERU_0A3 is selected |
| <b>EXS0B</b> | [3:2] | rw   | <b>External Source Select for B0 (ERS0)</b><br>This bit field defines which input is selected for B0.<br><br>00 <sub>B</sub> Input ERU_0B0 is selected<br>01 <sub>B</sub> Input ERU_0B1 is selected<br>10 <sub>B</sub> Input ERU_0B2 is selected<br>11 <sub>B</sub> Input ERU_0B3 is selected |
| <b>EXS1A</b> | [5:4] | rw   | <b>External Source Select for A1 (ERS1)</b><br>This bit field defines which input is selected for A1.<br><br>00 <sub>B</sub> Input ERU_1A0 is selected<br>01 <sub>B</sub> Input ERU_1A1 is selected<br>10 <sub>B</sub> Input ERU_1A2 is selected<br>11 <sub>B</sub> Input ERU_1A3 is selected |
| <b>EXS1B</b> | [7:6] | rw   | <b>External Source Select for B1 (ERS1)</b><br>This bit field defines which input is selected for B1.<br><br>00 <sub>B</sub> Input ERU_1B0 is selected<br>01 <sub>B</sub> Input ERU_1B1 is selected<br>10 <sub>B</sub> Input ERU_1B2 is selected<br>11 <sub>B</sub> Input ERU_1B3 is selected |

## System Control Unit (SCU)

| Field        | Bits    | Type | Description                                                                                                                                                                                                                                                                               |
|--------------|---------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>EXS2A</b> | [9:8]   | rw   | <b>External Source Select for A2 (ERS2)</b><br>This bit field defines which input is selected for A2.<br>00 <sub>B</sub> Input ERU_2A0 is selected<br>01 <sub>B</sub> Input ERU_2A1 is selected<br>10 <sub>B</sub> Input ERU_2A2 is selected<br>11 <sub>B</sub> Input ERU_2A3 is selected |
| <b>EXS2B</b> | [11:10] | rw   | <b>External Source Select for B2 (ERS2)</b><br>This bit field defines which input is selected for B2.<br>00 <sub>B</sub> Input ERU_2B0 is selected<br>01 <sub>B</sub> Input ERU_2B1 is selected<br>10 <sub>B</sub> Input ERU_2B2 is selected<br>11 <sub>B</sub> Input ERU_2B3 is selected |
| <b>EXS3A</b> | [13:12] | rw   | <b>External Source Select for A3 (ERS3)</b><br>This bit field defines which input is selected for A3.<br>00 <sub>B</sub> Input ERU_3A0 is selected<br>01 <sub>B</sub> Input ERU_3A1 is selected<br>10 <sub>B</sub> Input ERU_3A2 is selected<br>11 <sub>B</sub> Input ERU_3A3 is selected |
| <b>EXS3B</b> | [15:14] | rw   | <b>External Source Select for B3 (ERS3)</b><br>This bit field defines which input is selected for B3.<br>00 <sub>B</sub> Input ERU_3B0 is selected<br>01 <sub>B</sub> Input ERU_3B1 is selected<br>10 <sub>B</sub> Input ERU_3B2 is selected<br>11 <sub>B</sub> Input ERU_3B3 is selected |

## System Control Unit (SCU)

### 8.9.8.2 External Input Control Registers EXICONx

These registers control the inputs of the ERSx unit and the trigger functions of the ETLx units ( $x = 0..3$ ).

**EXICON0**
**External Input Control 0 Register**

 ESFR (F030<sub>H</sub>/18<sub>H</sub>)

 Reset Value: 0000<sub>H</sub>
**EXICON1**
**External Input Control 1 Register**

 ESFR (F032<sub>H</sub>/19<sub>H</sub>)

 Reset Value: 0000<sub>H</sub>
**EXICON2**
**External Input Control 2 Register**

 ESFR (F034<sub>H</sub>/1A<sub>H</sub>)

 Reset Value: 0000<sub>H</sub>
**EXICON3**
**External Input Control 3 Register**

 ESFR (F036<sub>H</sub>/1C<sub>H</sub>)

 Reset Value: 0000<sub>H</sub>

| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6   | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|
|    |    |    |    | 0  | NB | NA | SS | FL  | OCS | FE | RE | LD | PE |    |    |
| r  |    |    |    | rw | rw | rw | rw | rwh | rw  | rw | rw | rw | rw | rw | rw |

| Field | Bits | Type | Description                                                                                                                                                                                                                                                                                                       |
|-------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PE    | 0    | rw   | <b>Output Trigger Pulse Enable for ETLx</b><br>This bit enables the generation of an output trigger pulse at TRxy when the selected edge is detected (set condition for the status flag FL).<br>0 <sub>B</sub> The trigger pulse generation is disabled<br>1 <sub>B</sub> The trigger pulse generation is enabled |

## System Control Unit (SCU)

| Field | Bits  | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LD    | 1     | rw   | <b>Rebuild Level Detection for Status Flag for ETLx</b><br>This bit selects if the status flag FL is used as “sticky” bit or if it rebuilds the result of a level detection.<br>$0_B$ The status flag FL is not cleared by hardware and is used as “sticky” bit. Once set, it is not influenced by any edge until it becomes cleared by software.<br>$1_B$ The status flag FL rebuilds a level detection of the desired event. It becomes automatically set with a rising edge if RE = 1 or with a falling edge if FE = 1. It becomes automatically cleared with a rising edge if RE = 0 or with a falling edge if FE = 0. |
| RE    | 2     | rw   | <b>Rising Edge Detection Enable ETLx</b><br>This bit enables/disables the rising edge event as edge event as set condition for the status flag FL or as possible trigger pulse for TRxy.<br>$0_B$ A rising edge is not considered as edge event<br>$1_B$ A rising edge is considered as edge event                                                                                                                                                                                                                                                                                                                         |
| FE    | 3     | rw   | <b>Falling Edge Detection Enable ETLx</b><br>This bit enables/disables the falling edge event as edge event as set condition for the status flag FL or as possible trigger pulse for TRxy.<br>$0_B$ A falling edge is not considered as edge event<br>$1_B$ A falling edge is considered as edge event                                                                                                                                                                                                                                                                                                                     |
| OCS   | [6:4] | rw   | <b>Output Channel Select for ETLx Output Trigger Pulse</b><br>This bit field defines which Output Channel OGUy is targeted by an enabled trigger pulse TRxy.<br>$000_B$ Trigger pulses are sent to OGU0<br>$001_B$ Trigger pulses are sent to OGU1<br>$010_B$ Trigger pulses are sent to OGU2<br>$011_B$ Trigger pulses are sent to OGU3<br>$1XX_B$ Reserved, do not use this combination                                                                                                                                                                                                                                  |
| FL    | 7     | rwh  | <b>Status Flag for ETLx</b><br>This bit represents the status flag that becomes set or cleared by the edge detection.<br>$0_B$ The enabled edge event has not been detected<br>$1_B$ The enabled edge event has been detected                                                                                                                                                                                                                                                                                                                                                                                              |

## System Control Unit (SCU)

| Field     | Bits    | Type | Description                                                                                                                                                                                                                                                                                                              |
|-----------|---------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>SS</b> | [9:8]   | rw   | <b>Input Source Select for ERSx</b><br>This bit field defines which logical combination is taken into account as ESRxO.<br>00 <sub>B</sub> Input A without additional combination<br>01 <sub>B</sub> Input B without additional combination<br>10 <sub>B</sub> Input A OR input B<br>11 <sub>B</sub> Input A AND input B |
| <b>NA</b> | 10      | rw   | <b>Input A Negation Select for ERSx</b><br>This bit selects the polarity for the input A.<br>0 <sub>B</sub> Input A is used directly<br>1 <sub>B</sub> Input A is inverted                                                                                                                                               |
| <b>NB</b> | 11      | rw   | <b>Input B Negation Select for ERSx</b><br>This bit selects the polarity for the input B.<br>0 <sub>B</sub> Input B is used directly<br>1 <sub>B</sub> Input B is inverted                                                                                                                                               |
| <b>0</b>  | [15:12] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                  |

## System Control Unit (SCU)

### 8.9.8.3 Output Control Registers EXOCONy

These registers control the outputs of the Output Gating Unit y (y = 0..3).

#### EXOCON0

##### External Output Trigger Control 0 Register

SFR (FE30<sub>H</sub>/18<sub>H</sub>)

Reset Value: 0000<sub>H</sub>

#### EXOCON1

##### External Output Trigger Control 1 Register

SFR (FE32<sub>H</sub>/19<sub>H</sub>)

Reset Value: 0000<sub>H</sub>

#### EXOCON2

##### External Output Trigger Control 2 Register

SFR (FE34<sub>H</sub>/1A<sub>H</sub>)

Reset Value: 0000<sub>H</sub>

#### EXOCON3

##### External Output Trigger Control 3 Register

SFR (FE36<sub>H</sub>/1B<sub>H</sub>)

Reset Value: 0000<sub>H</sub>

| 15        | 14        | 13        | 12        | 11 | 10 | 9 | 8 | 7 | 6 | 5  | 4   | 3        | 2 | 1   | 0 |
|-----------|-----------|-----------|-----------|----|----|---|---|---|---|----|-----|----------|---|-----|---|
| IPEN<br>3 | IPEN<br>2 | IPEN<br>1 | IPEN<br>0 |    |    | 0 |   |   |   | GP | PDR | GE<br>EN |   | ISS |   |
| rw        | rw        | rw        | rw        |    |    | r |   |   |   | rw | rh  | rw       |   | rw  |   |

| Field | Bits  | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|-------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ISS   | [1:0] | rw   | <b>Internal Trigger Source Selection</b><br>This bit field defines which input is selected as peripheral trigger input for OGUy. The possible input signals are given in <a href="#">Table 8-20</a> . <ul style="list-style-type: none"> <li>00<sub>B</sub> The peripheral trigger function is disabled</li> <li>01<sub>B</sub> Input ERU_OGUy1 is selected</li> <li>10<sub>B</sub> Input ERU_OGUy2 is selected</li> <li>11<sub>B</sub> Input ERU_OGUy3 is selected</li> </ul> |
| GEEN  | 2     | rw   | <b>Gating Event Enable</b><br>Bit GEEN enables the generation of a trigger event when the result of the pattern detection changes from match to miss or vice-versa. <ul style="list-style-type: none"> <li>0<sub>B</sub> The event detection is disabled</li> <li>1<sub>B</sub> The event detection is enabled</li> </ul>                                                                                                                                                      |
| PDR   | 3     | rh   | <b>Pattern Detection Result Flag</b><br>This bit represents the pattern detection result. <ul style="list-style-type: none"> <li>0<sub>B</sub> A pattern miss is detected</li> <li>1<sub>B</sub> A pattern match is detected</li> </ul>                                                                                                                                                                                                                                        |

## System Control Unit (SCU)

| Field                      | Bits   | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------------|--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>GP</b>                  | [5:4]  | rw   | <b>Gating Selection for Pattern Detection Result</b><br>This bit field defines the gating scheme for the interrupt generation (relation between the OGU output ERU_PDOUTy and ERU_GOUTy). <ul style="list-style-type: none"> <li>00<sub>B</sub> ERU_GOUTy is always disabled and ERU_IOUTy can not be activated</li> <li>01<sub>B</sub> ERU_GOUTy is always enabled and ERU_IOUTy becomes activated with each activation of ERU_TOUTy</li> <li>10<sub>B</sub> ERU_GOUTy is equal to ERU_PDOUTy and ERU_IOUTy becomes activated with an activation of ERU_TOUTy while the desired pattern is detected (pattern match PDR = 1)</li> <li>11<sub>B</sub> ERU_GOUTy is inverted to ERU_PDOUTy and ERU_IOUTy becomes activated with an activation of ERU_TOUTy while the desired pattern is not detected (pattern miss PDR = 0)</li> </ul> |
| <b>IPENx<br/>(x = 0-3)</b> | 12+x   | rw   | <b>Pattern Detection Enable for ETLx</b><br>Bit IPENx defines whether the trigger event status flag EXICONx.FL of ETLx takes part in the pattern detection of OGUY. <ul style="list-style-type: none"> <li>0<sub>B</sub> Flag EXICONx.FL is excluded from the pattern detection</li> <li>1<sub>B</sub> Flag EXICONx.FL is included in the pattern detection</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| <b>0</b>                   | [11:6] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

## System Control Unit (SCU)

## 8.10 SCU Interrupt Generation

The interrupt structure of the SCU is shown in [Figure 8-29](#).



**Figure 8-29 SCU Interrupt Structure**

If enabled by the corresponding bit in register **INTDIS**, an interrupt is triggered either by the incoming interrupt request line, or by a software set of the respective bit in register **INTSET**. The trigger sets the respective flag in register **INTSTAT** and is gated to one of the interrupt nodes, selected by the node pointer registers **INTNP0** or **INTNP1**.

The interrupt flag can be cleared by software by writing to the corresponding bit in register **INTCLR**.

If more than one interrupt source is connected to the same interrupt node pointer (in register **INTNPx**), the requests are combined to one common line.

### Interrupt Node Assignment

The interrupt sources of the SCU module can be mapped to the dedicated interrupt node 6C<sub>H</sub> or 6B<sub>H</sub> by programming the interrupt node pointer registers **INTNP0** and **INTNP1**.

Furthermore, If the CAPCOM2 interrupts for channels 30 or 31 are not used the SCU interrupts can be mapped via register ISSR to the interrupt nodes 1E<sub>H</sub> or 1F<sub>H</sub> which are assigned to the CAPCOM2 interrupts. So for the SCU interrupts can be selected the interrupt node 6C<sub>H</sub>, 6B<sub>H</sub>, or in addition via register ISSR the node 1E<sub>H</sub> or 1F<sub>H</sub>.

The default assignment of the interrupt sources to the nodes and their corresponding control registers are shown in [Table 8-10](#).

## System Control Unit (SCU)

### 8.10.1 Interrupt Support

Some of the interrupt requests are first fed through a sticky flag register in the DMP\_M domain. These flags are set with a trigger and if set trigger the interrupt generation in the DMP\_1.. Please note that the disable control of register INTDIS also influences the sticky bit in register **DMPMIT** (see [Section 8.10.3.6](#)).

Which of the interrupt requests have a sticky flag in register DMPMIT is listed in [Table 8-10](#).

*Note: When servicing an SCU interrupt request, make sure that all related request flags are cleared after the identified request has been handled. To clear an interrupt request that is stored in register DMPMIT, first clear the request source of the source (e.g. WUTRG), clear the request within DMP\_M via DMPMITCLR, and then clear the request within DMP\_1 via INTCLR.*

### 8.10.2 SCU Interrupt Sources

The SCU receives the interrupt request lines listed in [Table 8-10](#).

**Table 8-10 SCU Interrupt Overview**

| Source of Interrupt      | Short Name | Sticky Flag in DMPMIT | Default Interrupt Node Assignment in INTNPx |
|--------------------------|------------|-----------------------|---------------------------------------------|
| SWD OK 1 Interrupt       | SWDI1      | yes                   | 6C <sub>H</sub>                             |
| SWD OK 2 Interrupt       | SWDI2      | yes                   | 6B <sub>H</sub>                             |
| PVC_M OK 1 Interrupt     | PVCMI1     | yes                   | 6C <sub>H</sub>                             |
| PVC_M OK 2 Interrupt     | PVCMI2     | yes                   | 6B <sub>H</sub>                             |
| PVC_1 OK 1 Interrupt     | PVC1I1     | yes                   | 6C <sub>H</sub>                             |
| PVC_1 OK 2 Interrupt     | PVC1I2     | yes                   | 6B <sub>H</sub>                             |
| Wake-up Timer Interrupt  | WUTI       | yes                   | 6B <sub>H</sub>                             |
| Wake-up Trim Interrupt   | WUI        | yes                   | 6C <sub>H</sub>                             |
| Watchdog Timer Interrupt | WDTI       | ---                   | 6B <sub>H</sub>                             |
| GSC Interrupt            | GSCI       | yes                   | 6C <sub>H</sub>                             |
| STM0 Interrupt           | STM0I      | yes                   | 6B <sub>H</sub>                             |
| STM1 Interrupt           | STM1I      | yes                   | 6C <sub>H</sub>                             |
| MCHK Interrupt           | MCHKI      | ---                   | 6B <sub>H</sub>                             |
| Program Flash Interrupt  | PFI        | ---                   | 6C <sub>H</sub>                             |

## System Control Unit (SCU)

## 8.10.3 Interrupt Control Registers

### 8.10.3.1 Register INTSTAT

This register contains the status flags for all interrupt request trigger sources of the SCU. For setting and clearing of these status bits by software see registers INTSET and INTCLR, respectively.

#### INTSTAT

##### Interrupt Status Register

**SFR (FF00<sub>H</sub>/80<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**

| 15 | 14      | 13            | 12       | 11            | 10 | 9   | 8   | 7  | 6   | 5       | 4       | 3       | 2       | 1   | 0   |
|----|---------|---------------|----------|---------------|----|-----|-----|----|-----|---------|---------|---------|---------|-----|-----|
|    |         |               |          |               |    | GSC | WDT | WU | WUT | PVC     | PVC     | PVC     | PVC     | SWD | SWD |
| 0  | PF<br>I | M<br>CHK<br>I | STM<br>1 | STM<br>0<br>I | I  | I   | I   | I  | I   | 1<br>I2 | 1<br>I1 | M<br>I2 | M<br>I1 | I2  | I1  |
| rh | rh      | rh            | rh       | rh            | rh | rh  | rh  | rh | rh  | rh      | rh      | rh      | rh      | rh  | rh  |

| Field  | Bits | Type | Description                                                                                                                                                                                                                                                                                  |
|--------|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SWDI1  | 0    | rh   | <b>SWD Interrupt Request Flag 1</b><br>This bit is set if bit DMPMIT.SWDI1 is set.<br>0 <sub>B</sub> No SWDI1 interrupt trigger has occurred since this bit was cleared the last time<br>1 <sub>B</sub> A SWDI1 interrupt trigger has occurred since this bit was cleared the last time      |
| SWDI2  | 1    | rh   | <b>SWD Interrupt Request Flag 2</b><br>This bit is set if bit DMPMIT.SWDI2 is set.<br>0 <sub>B</sub> No SWDI2 interrupt trigger has occurred since this bit was cleared the last time<br>1 <sub>B</sub> A SWDI2 interrupt trigger has occurred since this bit was cleared the last time      |
| PVCMI1 | 2    | rh   | <b>PVC_M Interrupt Request Flag 1</b><br>This bit is set if bit DMPMIT.PVCMI1 is set.<br>0 <sub>B</sub> No PVCMI1 interrupt trigger has occurred since this bit was cleared the last time<br>1 <sub>B</sub> A PVCMI1 interrupt trigger has occurred since this bit was cleared the last time |

## System Control Unit (SCU)

| Field  | Bits | Type | Description                                                                                                                                                                                                                                                                                                                          |
|--------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PVCMI2 | 3    | rh   | <b>PVC_M Interrupt Request Flag 2</b><br>This bit is set if bit DMPMIT.PVCMI2 is set.<br>0 <sub>B</sub> No PVCMI2 interrupt trigger has occurred since this bit was cleared the last time<br>1 <sub>B</sub> A PVCMI2 interrupt trigger has occurred since this bit was cleared the last time                                         |
| PVC1I1 | 4    | rh   | <b>PVC_1 Interrupt Request Flag 1</b><br>This bit is set if bit DMPMIT.PVC1I1 is set.<br>0 <sub>B</sub> No PVC1I1 interrupt trigger has occurred since this bit was cleared the last time<br>1 <sub>B</sub> A PVC1I1 interrupt trigger has occurred since this bit was cleared the last time                                         |
| PVC1I2 | 5    | rh   | <b>PVC_1 Interrupt Request Flag 2</b><br>This bit is set if bit DMPMIT.PVC1I2 is set.<br>0 <sub>B</sub> No PVC1I2 interrupt trigger has occurred since this bit was cleared the last time<br>1 <sub>B</sub> A PVC1I2 interrupt trigger has occurred since this bit was cleared the last time                                         |
| WUTI   | 6    | rh   | <b>Wake-up Timer Trim Interrupt Request Flag</b><br>This bit is set if the WUT trim trigger event occur and bit is INTDIS.WUTI = 0.<br>0 <sub>B</sub> No WUT interrupt trigger has occurred since this bit was cleared the last time<br>1 <sub>B</sub> A WUT interrupt trigger has occurred since this bit was cleared the last time |
| WUI    | 7    | rh   | <b>Wake-up Timer Interrupt Request Flag</b><br>This bit is set if the WU trigger event occur and bit is INTDIS.WUI = 0.<br>0 <sub>B</sub> No WU interrupt trigger has occurred since this bit was cleared the last time<br>1 <sub>B</sub> A WU interrupt trigger has occurred since this bit was cleared the last time               |
| WDTI   | 8    | rh   | <b>Watchdog Timer Interrupt Request Flag</b><br>This bit is set if the WDT Prewarning Mode is entered and bit is INTDIS.WDTI = 0.<br>0 <sub>B</sub> No WDT interrupt trigger has occurred since this bit was cleared the last time<br>1 <sub>B</sub> A WDT interrupt trigger has occurred since this bit was cleared the last time   |

## System Control Unit (SCU)

| Field        | Bits    | Type | Description                                                                                                                                                                                                                                                                                                          |
|--------------|---------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>GSCI</b>  | 9       | rh   | <b>GSC Interrupt Request Flag</b><br>This bit is set if the GSC error bit is set and bit is INTDIS.GSCI = 0.<br>$0_B$ No GSC interrupt trigger has occurred since this bit was cleared the last time<br>$1_B$ A GSC interrupt trigger has occurred since this bit was cleared the last time                          |
| <b>STM0I</b> | 10      | rh   | <b>STM Interrupt 0 Request Flag</b><br>This bit is set if the STM interrupt trigger 0 is set and bit is INTDIS.STM0I = 0.<br>$0_B$ No STM0 interrupt trigger has occurred since this bit was cleared the last time<br>$1_B$ A STM0 interrupt trigger has occurred since this bit was cleared the last time           |
| <b>STM1I</b> | 11      | rh   | <b>STM Interrupt 1 Request Flag</b><br>This bit is set if the STM interrupt trigger 1 is set and bit is INTDIS.STM1I = 0.<br>$0_B$ No STM1 interrupt trigger has occurred since this bit was cleared the last time<br>$1_B$ A STM1 interrupt trigger has occurred since this bit was cleared the last time           |
| <b>MCHKI</b> | 12      | rh   | <b>MCHK Interrupt Request Flag</b><br>This bit is set if the MCHK interrupt trigger is set and bit is INTDIS.MCHKI = 0.<br>$0_B$ No MCHK interrupt trigger has occurred since this bit was cleared the last time<br>$1_B$ A MCHK interrupt trigger has occurred since this bit was cleared the last time             |
| <b>PFI</b>   | 13      | rh   | <b>Program Flash Interrupt Request Flag</b><br>This bit is set if the Program Flash interrupt trigger is set and bit is INTDIS.PFI = 0.<br>$0_B$ No PF interrupt trigger has occurred since this bit was cleared the last time<br>$1_B$ A PF interrupt trigger has occurred since this bit was cleared the last time |
| <b>0</b>     | [15:14] | rh   | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                              |

## System Control Unit (SCU)

### 8.10.3.2 Register INTCLR

This register contains the software clear option for all status flags of all interrupt request trigger sources of the SCU.

**INTCLR**
**Interrupt Clear Register**
**SFR (FE82<sub>H</sub>/41<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**

| 15 | 14      | 13            | 12            | 11            | 10       | 9        | 8       | 7        | 6              | 5              | 4              | 3              | 2         | 1         | 0 |
|----|---------|---------------|---------------|---------------|----------|----------|---------|----------|----------------|----------------|----------------|----------------|-----------|-----------|---|
| 0  | PF<br>I | M<br>CHK<br>I | STM<br>1<br>I | STM<br>0<br>I | GSC<br>I | WDT<br>I | WU<br>I | WUT<br>I | PVC<br>1<br>I2 | PVC<br>1<br>I1 | PVC<br>M<br>I2 | PVC<br>M<br>I1 | SWD<br>I2 | SWD<br>I1 |   |

| Field         | Bits | Type | Description                                                                                              |
|---------------|------|------|----------------------------------------------------------------------------------------------------------|
| <b>SWDI1</b>  | 0    | w    | <b>Clear SWD Interrupt Request Flag 1</b><br>$0_B$ No action<br>$1_B$ Bit INTSTAT.SWDI1 is cleared       |
| <b>SWDI2</b>  | 1    | w    | <b>Clear SWD Interrupt Request Flag 2</b><br>$0_B$ No action<br>$1_B$ Bit INTSTAT.SWDI2 is cleared       |
| <b>PVCM1</b>  | 2    | w    | <b>Clear PVC_M Interrupt Request Flag 1</b><br>$0_B$ No action<br>$1_B$ Bit INTSTAT.PVCM1 is cleared     |
| <b>PVCM2</b>  | 3    | w    | <b>Clear PVC_M Interrupt Request Flag 2</b><br>$0_B$ No action<br>$1_B$ Bit INTSTAT.PVCM2 is cleared     |
| <b>PVC1I1</b> | 4    | w    | <b>Clear PVC_1 Interrupt Request Flag 1</b><br>$0_B$ No action<br>$1_B$ Bit INTSTAT.PVC1I1 is cleared    |
| <b>PVC1I2</b> | 5    | w    | <b>Clear PVC_1 Interrupt Request Flag 2</b><br>$0_B$ No action<br>$1_B$ Bit INTSTAT.PVC1I2 is cleared    |
| <b>WUTI</b>   | 6    | w    | <b>Clear Wake-up Trim Interrupt Request Flag</b><br>$0_B$ No action<br>$1_B$ Bit INTSTAT.WUTI is cleared |
| <b>WUI</b>    | 7    | w    | <b>Clear Wake-up Interrupt Request Flag</b><br>$0_B$ No action<br>$1_B$ Bit INTSTAT.WUI is cleared       |

## System Control Unit (SCU)

| Field        | Bits    | Type | Description                                                                                                |
|--------------|---------|------|------------------------------------------------------------------------------------------------------------|
| <b>WDTI</b>  | 8       | w    | <b>Clear Watchdog Timer Interrupt Request Flag</b><br>$0_B$ No action<br>$1_B$ Bit INTSTAT.WDTI is cleared |
| <b>GSCI</b>  | 9       | w    | <b>Clear GSC Interrupt Request Flag</b><br>$0_B$ No action<br>$1_B$ Bit INTSTAT.GSCI is cleared            |
| <b>STM0I</b> | 10      | w    | <b>Clear STM0 Interrupt Request Flag</b><br>$0_B$ No action<br>$1_B$ Bit INTSTAT.STM0I is cleared          |
| <b>STM1I</b> | 11      | w    | <b>Clear STM1 Interrupt Request Flag</b><br>$0_B$ No action<br>$1_B$ Bit INTSTAT.STM1I is cleared          |
| <b>MCHKI</b> | 12      | w    | <b>Clear MCHK Interrupt Request Flag</b><br>$0_B$ No action<br>$1_B$ Bit INTSTAT.MCHKI is cleared          |
| <b>PFI</b>   | 13      | w    | <b>Clear Program Flash Interrupt Request Flag</b><br>$0_B$ No action<br>$1_B$ Bit INTSTAT.PFI is cleared   |
| <b>0</b>     | [15:14] | w    | <b>Reserved</b><br>Must be written with 0.                                                                 |

## System Control Unit (SCU)

### 8.10.3.3 Register INTSET

This register contains the software set option for all status flags of all interrupt request trigger sources of the SCU.

**INTSET**
**Interrupt Set Register**
**SFR (FE80<sub>H</sub>/40<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**

| 15 | 14      | 13            | 12            | 11            | 10       | 9        | 8       | 7        | 6              | 5              | 4              | 3              | 2         | 1         | 0 |
|----|---------|---------------|---------------|---------------|----------|----------|---------|----------|----------------|----------------|----------------|----------------|-----------|-----------|---|
| 0  | PF<br>I | M<br>CHK<br>I | STM<br>1<br>I | STM<br>0<br>I | GSC<br>I | WDT<br>I | WU<br>I | WUT<br>I | PVC<br>1<br>I2 | PVC<br>1<br>I1 | PVC<br>M<br>I2 | PVC<br>M<br>I1 | SWD<br>I2 | SWD<br>I1 |   |

| Field         | Bits | Type | Description                                                                                                          |
|---------------|------|------|----------------------------------------------------------------------------------------------------------------------|
| <b>SWDI1</b>  | 0    | w    | <b>Set SWD Interrupt Request Flag 1</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit INTSTAT.SWDI1 is set       |
| <b>SWDI2</b>  | 1    | w    | <b>Set SWD Interrupt Request Flag 2</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit INTSTAT.SWDI2 is set       |
| <b>PVCM1</b>  | 2    | w    | <b>Set PVC_M Interrupt Request Flag 1</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit INTSTAT.PVCM1 is set     |
| <b>PVCM2</b>  | 3    | w    | <b>Set PVC_M Interrupt Request Flag 2</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit INTSTAT.PVCM2 is set     |
| <b>PVC1I1</b> | 4    | w    | <b>Set PVC_1 Interrupt Request Flag 1</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit INTSTAT.PVC1I1 is set    |
| <b>PVC1I2</b> | 5    | w    | <b>Set PVC_1 Interrupt Request Flag 2</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit INTSTAT.PVC1I2 is set    |
| <b>WUTI</b>   | 6    | w    | <b>Set Wake-up Trim Interrupt Request Flag</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit INTSTAT.WUTI is set |
| <b>WUI</b>    | 7    | w    | <b>Set Wake-up Interrupt Request Flag</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit INTSTAT.WUI is set       |

## System Control Unit (SCU)

| Field        | Bits    | Type | Description                                                                                          |
|--------------|---------|------|------------------------------------------------------------------------------------------------------|
| <b>WDTI</b>  | 8       | w    | <b>Set Watchdog Timer Interrupt Request Flag</b><br>$0_B$ No action<br>$1_B$ Bit INTSTAT.WDTI is set |
| <b>GSCI</b>  | 9       | w    | <b>Set GSC Interrupt Request Flag</b><br>$0_B$ No action<br>$1_B$ Bit INTSTAT.GSCI is set            |
| <b>STM0I</b> | 10      | w    | <b>Set STM0 Interrupt Request Flag</b><br>$0_B$ No action<br>$1_B$ Bit INTSTAT.STM0I is set          |
| <b>STM1I</b> | 11      | w    | <b>Set STM1 Interrupt Request Flag</b><br>$0_B$ No action<br>$1_B$ Bit INTSTAT.STM1I is set          |
| <b>MCHKI</b> | 12      | w    | <b>Set MCHK Interrupt Request Flag</b><br>$0_B$ No action<br>$1_B$ Bit INTSTAT.MCHKI is set          |
| <b>PFI</b>   | 13      | w    | <b>Set Program Flash Interrupt Request Flag</b><br>$0_B$ No action<br>$1_B$ Bit INTSTAT.PFI is set   |
| <b>0</b>     | [15:14] | w    | <b>Reserved</b><br>Must be written with 0.                                                           |

## System Control Unit (SCU)

### 8.10.3.4 Register INTDIS

This register contains the software disable control for all interrupt request trigger sources of the SCU.

**INTDIS**
**Interrupt Disable Register**
**SFR (FE84<sub>H</sub>/42<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**

| 15 | 14      | 13            | 12            | 11            | 10       | 9        | 8       | 7        | 6              | 5              | 4              | 3              | 2         | 1         | 0 |
|----|---------|---------------|---------------|---------------|----------|----------|---------|----------|----------------|----------------|----------------|----------------|-----------|-----------|---|
| 0  | PF<br>I | M<br>CHK<br>I | STM<br>1<br>I | STM<br>0<br>I | GSC<br>I | WDT<br>I | WU<br>I | WUT<br>I | PVC<br>1<br>I2 | PVC<br>1<br>I1 | PVC<br>M<br>I2 | PVC<br>M<br>I1 | SWD<br>I2 | SWD<br>I1 |   |

| Field         | Bits | Type | Description                                                                                                                                     |
|---------------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>SWDI1</b>  | 0    | rw   | <b>Disable SWD Interrupt Request 1</b><br>0 <sub>B</sub> SWDI1 interrupt request enabled<br>1 <sub>B</sub> SWDI1 interrupt request disabled     |
| <b>SWDI2</b>  | 1    | rw   | <b>Disable SWD Interrupt Request 2</b><br>0 <sub>B</sub> SWDI2 interrupt request enabled<br>1 <sub>B</sub> SWDI2 interrupt request disabled     |
| <b>PVCM1I</b> | 2    | rw   | <b>Disable PVC_M Interrupt Request 1</b><br>0 <sub>B</sub> PVCM1I interrupt request enabled<br>1 <sub>B</sub> PVCM1I interrupt request disabled |
| <b>PVCM2I</b> | 3    | rw   | <b>Disable PVC_M Interrupt Request 2</b><br>0 <sub>B</sub> PVCM2I interrupt request enabled<br>1 <sub>B</sub> PVCM2I interrupt request disabled |
| <b>PVC1I1</b> | 4    | rw   | <b>Disable PVC_1 Interrupt Request 1</b><br>0 <sub>B</sub> PVC1I1 interrupt request enabled<br>1 <sub>B</sub> PVC1I1 interrupt request disabled |
| <b>PVC1I2</b> | 5    | rw   | <b>Disable PVC_1 Interrupt Request 2</b><br>0 <sub>B</sub> PVC1I2 interrupt request enabled<br>1 <sub>B</sub> PVC1I2 interrupt request disabled |
| <b>WUTI</b>   | 6    | rw   | <b>Disable Wake-up Trim Interrupt Request</b><br>0 <sub>B</sub> WUT interrupt request enabled<br>1 <sub>B</sub> WUT interrupt request disabled  |
| <b>WUI</b>    | 7    | rw   | <b>Disable Wake-up Interrupt Request</b><br>0 <sub>B</sub> WU interrupt request enabled<br>1 <sub>B</sub> WU interrupt request disabled         |

## System Control Unit (SCU)

| Field        | Bits    | Type | Description                                                                                                                    |
|--------------|---------|------|--------------------------------------------------------------------------------------------------------------------------------|
| <b>WDTI</b>  | 8       | rw   | <b>Disable Watchdog Timer Interrupt Request</b><br>$0_B$ WDT interrupt request enabled<br>$1_B$ WDT interrupt request disabled |
| <b>GSCI</b>  | 9       | rw   | <b>Disable GSC Interrupt Request</b><br>$0_B$ GSC interrupt request enabled<br>$1_B$ GSC interrupt request disabled            |
| <b>STM0I</b> | 10      | rw   | <b>Disable STM0 Interrupt Request</b><br>$0_B$ STM0 interrupt request enabled<br>$1_B$ STM0 interrupt request disabled         |
| <b>STM1I</b> | 11      | rw   | <b>Disable STM1 Interrupt Request</b><br>$0_B$ STM1 interrupt request enabled<br>$1_B$ STM1 interrupt request disabled         |
| <b>MCHKI</b> | 12      | rw   | <b>Disable MCHK Interrupt Request</b><br>$0_B$ MCHK interrupt request enabled<br>$1_B$ MCHK interrupt request disabled         |
| <b>PFI</b>   | 13      | rw   | <b>Disable Program Flash Interrupt Request</b><br>$0_B$ PF interrupt request enabled<br>$1_B$ PF interrupt request disabled    |
| <b>0</b>     | [15:14] | rw   | <b>Reserved</b><br>Should be written with 0.                                                                                   |

### 8.10.3.5 Registers INTNP0 and INPNP1

These registers contain the control for the interrupt node pointers of all interrupt request trigger sources of the SCU.

#### INTNP0

##### Interrupt Node Pointer 0 Register

 SFR (FE86<sub>H</sub>/43<sub>H</sub>)

 Reset Value: 4444<sub>H</sub>

| 15 | 14  | 13    | 12    | 11    | 10    | 9    | 8    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|-----|-------|-------|-------|-------|------|------|---|---|---|---|---|---|---|---|
| WU | WUT | PVC12 | PVC11 | PVCM2 | PVCM1 | SWD2 | SWD1 |   |   |   |   |   |   |   |   |

rw            rw

| Field | Bits  | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SWD1  | [1:0] | rw   | <b>Interrupt Node Pointer for SWD 1 Interrupts</b><br>This bit field defines the interrupt node, which is requested due to the set condition for bit INTSTAT.SWDI1 (if enabled by bit INTDIS.SWDI1). <ul style="list-style-type: none"> <li>00<sub>B</sub> Interrupt node 6C<sub>H</sub> is selected</li> <li>01<sub>B</sub> Interrupt node 6B<sub>H</sub> is selected</li> <li>10<sub>B</sub> Interrupt node 1E<sub>H</sub> is selected if enabled by bit ISSR.ISS14 (bit is set)</li> <li>11<sub>B</sub> Interrupt node 1F<sub>H</sub> is selected if enabled by bit ISSR.ISS15 (bit is set)</li> </ul> |
| SWD2  | [3:2] | rw   | <b>Interrupt Node Pointer for SWD 2 Interrupts</b><br>This bit field defines the interrupt node, which is requested due to the set condition for bit INTSTAT.SWDI2 (if enabled by bit INTDIS.SWDI2). <ul style="list-style-type: none"> <li>00<sub>B</sub> Interrupt node 6C<sub>H</sub> is selected</li> <li>01<sub>B</sub> Interrupt node 6B<sub>H</sub> is selected</li> <li>10<sub>B</sub> Interrupt node 1E<sub>H</sub> is selected if enabled by bit ISSR.ISS14 (bit is set)</li> <li>11<sub>B</sub> Interrupt node 1F<sub>H</sub> is selected if enabled by bit ISSR.ISS15 (bit is set)</li> </ul> |

## System Control Unit (SCU)

| Field | Bits    | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|---------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PVCM1 | [5:4]   | rw   | <b>Interrupt Node Pointer for PVC_M 1 Interrupts</b><br>This bit field defines the interrupt node, which is requested due to the set condition for bit INTSTAT.PCVMI1 (if enabled by bit INTDIS.PVCM1).<br>00 <sub>B</sub> Interrupt node 6C <sub>H</sub> is selected<br>01 <sub>B</sub> Interrupt node 6B <sub>H</sub> is selected<br>10 <sub>B</sub> Interrupt node 1E <sub>H</sub> is selected if enabled by bit ISSR.ISS14 (bit is set)<br>11 <sub>B</sub> Interrupt node 1F <sub>H</sub> is selected if enabled by bit ISSR.ISS15 (bit is set)  |
| PVCM2 | [7:6]   | rw   | <b>Interrupt Node Pointer for PVC_M 2 Interrupts</b><br>This bit field defines the interrupt node, which is requested due to the set condition for bit INTSTAT.PCVMI2 (if enabled by bit INTDIS.PVCM2).<br>00 <sub>B</sub> Interrupt node 6C <sub>H</sub> is selected<br>01 <sub>B</sub> Interrupt node 6B <sub>H</sub> is selected<br>10 <sub>B</sub> Interrupt node 1E <sub>H</sub> is selected if enabled by bit ISSR.ISS14 (bit is set)<br>11 <sub>B</sub> Interrupt node 1F <sub>H</sub> is selected if enabled by bit ISSR.ISS15 (bit is set)  |
| PVC11 | [9:8]   | rw   | <b>Interrupt Node Pointer for PVC_1 1 Interrupts</b><br>This bit field defines the interrupt node, which is requested due to the set condition for bit INTSTAT.PCV1I1 (if enabled by bit INTDIS.PVC1I1).<br>00 <sub>B</sub> Interrupt node 6C <sub>H</sub> is selected<br>01 <sub>B</sub> Interrupt node 6B <sub>H</sub> is selected<br>10 <sub>B</sub> Interrupt node 1E <sub>H</sub> is selected if enabled by bit ISSR.ISS14 (bit is set)<br>11 <sub>B</sub> Interrupt node 1F <sub>H</sub> is selected if enabled by bit ISSR.ISS15 (bit is set) |
| PVC12 | [11:10] | rw   | <b>Interrupt Node Pointer for PVC_1 2 Interrupts</b><br>This bit field defines the interrupt node, which is requested due to the set condition for bit INTSTAT.PCV1I2 (if enabled by bit INTDIS.PVC1I2).<br>00 <sub>B</sub> Interrupt node 6C <sub>H</sub> is selected<br>01 <sub>B</sub> Interrupt node 6B <sub>H</sub> is selected<br>10 <sub>B</sub> Interrupt node 1E <sub>H</sub> is selected if enabled by bit ISSR.ISS14 (bit is set)<br>11 <sub>B</sub> Interrupt node 1F <sub>H</sub> is selected if enabled by bit ISSR.ISS15 (bit is set) |

## System Control Unit (SCU)

| Field      | Bits    | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|---------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>WUT</b> | [13:12] | rw   | <p><b>Interrupt Node Pointer for WU Trim Interrupts</b></p> <p>This bit field defines the interrupt node, which is requested due to the set condition for bit INTSTAT.WUTI (if enabled by bit INTDIS.WUTI).</p> <ul style="list-style-type: none"> <li>00<sub>B</sub> Interrupt node 6C<sub>H</sub> is selected</li> <li>01<sub>B</sub> Interrupt node 6B<sub>H</sub> is selected</li> <li>10<sub>B</sub> Interrupt node 1E<sub>H</sub> is selected if enabled by bit ISSR.ISS14 (bit is set)</li> <li>11<sub>B</sub> Interrupt node 1F<sub>H</sub> is selected if enabled by bit ISSR.ISS15 (bit is set)</li> </ul> |
| <b>WU</b>  | [15:14] | rw   | <p><b>Interrupt Node Pointer for WU Interrupts</b></p> <p>This bit field defines the interrupt node, which is requested due to the set condition for bit INTSTAT.WUI (if enabled by bit INTDIS.WUI).</p> <ul style="list-style-type: none"> <li>00<sub>B</sub> Interrupt node 6C<sub>H</sub> is selected</li> <li>01<sub>B</sub> Interrupt node 6B<sub>H</sub> is selected</li> <li>10<sub>B</sub> Interrupt node 1E<sub>H</sub> is selected if enabled by bit ISSR.ISS14 (bit is set)</li> <li>11<sub>B</sub> Interrupt node 1F<sub>H</sub> is selected if enabled by bit ISSR.ISS15 (bit is set)</li> </ul>        |

**INTNP1**
**Interrupt Node Pointer 1 Register**

 SFR (FE88<sub>H</sub>/44<sub>H</sub>)

 Reset Value: 1111<sub>H</sub>

| 15 | 14 | 13 | 12 | 11 | 10   | 9    | 8    | 7   | 6   | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|------|------|------|-----|-----|----|----|----|----|----|----|
|    | -  |    |    | PF | MCHK | STM1 | STM0 | GSC | WDT |    |    |    |    |    |    |
|    | -  |    |    | rw | rw   | rw   | rw   | rw  | rw  | rw | rw | rw | rw | rw | rw |

| Field       | Bits  | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------|-------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>WDT</b>  | [1:0] | rw   | <b>Interrupt Node Pointer for WDT Interrupts</b><br>This bit field defines the interrupt node, which is requested due to the set condition for bit INTSTAT.WDTI (if enabled by bit INTDIS.WDTI).<br>00 <sub>B</sub> Interrupt node 6C <sub>H</sub> is selected<br>01 <sub>B</sub> Interrupt node 6B <sub>H</sub> is selected<br>10 <sub>B</sub> Interrupt node 1E <sub>H</sub> is selected if enabled by bit ISSR.ISS14 (bit is set)<br>11 <sub>B</sub> Interrupt node 1F <sub>H</sub> is selected if enabled by bit ISSR.ISS15 (bit is set)    |
| <b>GSC</b>  | [3:2] | rw   | <b>Interrupt Node Pointer for GSC Interrupts</b><br>This bit field defines the interrupt node, which is requested due to the set condition for bit INTSTAT.GSCI (if enabled by bit INTDIS.GSCI).<br>00 <sub>B</sub> Interrupt node 6C <sub>H</sub> is selected<br>01 <sub>B</sub> Interrupt node 6B <sub>H</sub> is selected<br>10 <sub>B</sub> Interrupt node 1E <sub>H</sub> is selected if enabled by bit ISSR.ISS14 (bit is set)<br>11 <sub>B</sub> Interrupt node 1F <sub>H</sub> is selected if enabled by bit ISSR.ISS15 (bit is set)    |
| <b>STM0</b> | [5:4] | rw   | <b>Interrupt Node Pointer for STM0 Interrupts</b><br>This bit field defines the interrupt node, which is requested due to the set condition for bit INTSTAT.STM0I (if enabled by bit INTDIS.STM0I).<br>00 <sub>B</sub> Interrupt node 6C <sub>H</sub> is selected<br>01 <sub>B</sub> Interrupt node 6B <sub>H</sub> is selected<br>10 <sub>B</sub> Interrupt node 1E <sub>H</sub> is selected if enabled by bit ISSR.ISS14 (bit is set)<br>11 <sub>B</sub> Interrupt node 1F <sub>H</sub> is selected if enabled by bit ISSR.ISS15 (bit is set) |

## System Control Unit (SCU)

| Field       | Bits    | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------|---------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>STM1</b> | [7:6]   | rw   | <b>Interrupt Node Pointer for STM1 Interrupts</b><br>This bit field defines the interrupt node, which is requested due to the set condition for bit INTSTAT.STM1I (if enabled by bit INTDIS.STM1I).<br>00 <sub>B</sub> Interrupt node 6C <sub>H</sub> is selected<br>01 <sub>B</sub> Interrupt node 6B <sub>H</sub> is selected<br>10 <sub>B</sub> Interrupt node 1E <sub>H</sub> is selected if enabled by bit ISSR.ISS14 (bit is set)<br>11 <sub>B</sub> Interrupt node 1F <sub>H</sub> is selected if enabled by bit ISSR.ISS15 (bit is set)      |
| <b>MCHK</b> | [9:8]   | rw   | <b>Interrupt Node Pointer for MCHK Interrupts</b><br>This bit field defines the interrupt node, which is requested due to the set condition for bit INTSTAT.MCHKI (if enabled by bit INTDIS.MCHKI).<br>00 <sub>B</sub> Interrupt node 6C <sub>H</sub> is selected<br>01 <sub>B</sub> Interrupt node 6B <sub>H</sub> is selected<br>10 <sub>B</sub> Interrupt node 1E <sub>H</sub> is selected if enabled by bit ISSR.ISS14 (bit is set)<br>11 <sub>B</sub> Interrupt node 1F <sub>H</sub> is selected if enabled by bit ISSR.ISS15 (bit is set)      |
| <b>PF</b>   | [11:10] | rw   | <b>Interrupt Node Pointer for Program Flash Interrupts</b><br>This bit field defines the interrupt node, which is requested due to the set condition for bit INTSTAT.PFI (if enabled by bit INTDIS.PFI).<br>00 <sub>B</sub> Interrupt node 6C <sub>H</sub> is selected<br>01 <sub>B</sub> Interrupt node 6B <sub>H</sub> is selected<br>10 <sub>B</sub> Interrupt node 1E <sub>H</sub> is selected if enabled by bit ISSR.ISS14 (bit is set)<br>11 <sub>B</sub> Interrupt node 1F <sub>H</sub> is selected if enabled by bit ISSR.ISS15 (bit is set) |

## System Control Unit (SCU)

### 8.10.3.6 Register DMPMIT

This register contains additional sticky interrupt and trap flags within the DMP\_M power domain.

#### DMPMIT

##### DMP\_M Interrupt and Trap Trigger Register

 SFR (FE96<sub>H</sub>/4B<sub>H</sub>)

 Reset Value: 0000<sub>H</sub>

|    | 15 | 14  | 13  | 12  | 11  | 10  | 9   | 8  | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0  |
|----|----|-----|-----|-----|-----|-----|-----|----|-----|-----|-----|-----|-----|-----|-----|----|
| RA | 0  | ESR | ESR | ESR | STM | STM | GSC | WU | WUT | PVC | PVC | PVC | PVC | SWD | SWD |    |
| T  | 2  | T   | 1   | T   | 1   | 0   |     | I  | I   | 1   | 1   | M   | M   | I2  | I1  |    |
|    | rh | r   | rh  | rh  | rh  | rh  | rh  | rh | rh  | rh  | rh  | rh  | rh  | rh  | rh  | rh |

| Field        | Bits | Type | Description                                                                                                                                                                                                                                                                                                                                   |
|--------------|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>SWDI1</b> | 0    | rh   | <b>SWD Interrupt Request Flag 1</b><br>This bit is set if bit SWDCON0.L1OK is cleared and SWDCON0.L1INTEN = 1 <sub>B</sub> and INTDIS.SWDI1 = 0.<br>0 <sub>B</sub> No SWDI1 interrupt was requested since this bit was cleared the last time<br>1 <sub>B</sub> A SWDI1 interrupt was requested since this bit was cleared the last time       |
| <b>SWDI2</b> | 1    | rh   | <b>SWD Interrupt Request Flag 2</b><br>This bit is set if bit SWDCON0.L2OK is cleared and SWDCON0.L2INTEN = 1 <sub>B</sub> and INTDIS.SWDI2 = 0.<br>0 <sub>B</sub> No SWDI2 interrupt was requested since this bit was cleared the last time<br>1 <sub>B</sub> A SWDI2 interrupt was requested since this bit was cleared the last time       |
| <b>PVCM1</b> | 2    | rh   | <b>PVC_M Interrupt Request Flag 1</b><br>This bit is set if bit PVCMCON0.LEV1OK is cleared and PVCMCON0.L1INTEN = 1 <sub>B</sub> and INTDIS.PVCM1 = 0.<br>0 <sub>B</sub> No PVCM1 interrupt was requested since this bit was cleared the last time<br>1 <sub>B</sub> A PVCM1 interrupt was requested since this bit was cleared the last time |

## System Control Unit (SCU)

| Field  | Bits | Type | Description                                                                                                                                                                                                                                                                                                                                      |
|--------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PVCMI2 | 3    | rh   | <b>PVC_M Interrupt Request Flag 2</b><br>This bit is set if bit PVCMCON0.LEV2OK is cleared and PVCMCON0.L2INTEN = 1 <sub>B</sub> and INTDIS.PVCMI2 = 0.<br>0 <sub>B</sub> No PVCMI2 interrupt was requested since this bit was cleared the last time<br>1 <sub>B</sub> A PVCMI2 interrupt was requested since this bit was cleared the last time |
| PVC1I1 | 4    | rh   | <b>PVC_1 Interrupt Request Flag 1</b><br>This bit is set if bit PVC1CON0.LEV1OK is cleared and PVC1CON0.L1INTEN = 1 <sub>B</sub> and INTDIS.PVC1I1 = 0.<br>0 <sub>B</sub> No PVC1I1 interrupt was requested since this bit was cleared the last time<br>1 <sub>B</sub> A PVC1I1 interrupt was requested since this bit was cleared the last time |
| PVC1I2 | 5    | rh   | <b>PVC_1 Interrupt Request Flag 2</b><br>This bit is set if bit PVC1CON0.LEV2OK is cleared and PVC1CON0.L2INTEN = 1 <sub>B</sub> and INTDIS.PVC1I2 = 0.<br>0 <sub>B</sub> No PVC1I2 interrupt was requested since this bit was cleared the last time<br>1 <sub>B</sub> A PVC1I2 interrupt was requested since this bit was cleared the last time |
| WUTI   | 6    | rh   | <b>Wake-up Trim Interrupt Request Flag</b><br>This bit is set if a wake-up trim trigger occurs and INTDIS.WUTI = 0.<br>0 <sub>B</sub> No WUT interrupt was requested since this bit was cleared the last time<br>1 <sub>B</sub> A WUT interrupt was requested since this bit was cleared the last time                                           |
| WUI    | 7    | rh   | <b>Wake-up Interrupt Request Flag</b><br>This bit is set if a wake-up trigger occurs and INTDIS.WUI = 0.<br>0 <sub>B</sub> No WU interrupt was requested since this bit was cleared the last time<br>1 <sub>B</sub> A WU interrupt was requested since this bit was cleared the last time                                                        |

## System Control Unit (SCU)

| Field        | Bits | Type | Description                                                                                                                                                                                                                                                             |
|--------------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>GSC</b>   | 8    | rh   | <b>GSC Interrupt Request Flag</b><br>This bit is set if a GSC trigger occurs and INTDIS.GSCI = 0.<br>$0_B$ No GSC interrupt was requested since this bit was cleared the last time<br>$1_B$ A GSC interrupt was requested since this bit was cleared the last time      |
| <b>STM0</b>  | 9    | rh   | <b>STM0 Interrupt Request Flag</b><br>This bit is set if a STM0 trigger occurs and INTDIS.STM0I = 0.<br>$0_B$ No STM0 interrupt was requested since this bit was cleared the last time<br>$1_B$ A STM0 interrupt was requested since this bit was cleared the last time |
| <b>STM1</b>  | 10   | rh   | <b>STM1 Interrupt Request Flag</b><br>This bit is set if a STM1 trigger occurs and INTDIS.STM1I = 0.<br>$0_B$ No STM1 interrupt was requested since this bit was cleared the last time<br>$1_B$ A STM1 interrupt was requested since this bit was cleared the last time |
| <b>ESR0T</b> | 11   | rh   | <b>ESR0 Trap Request Flag</b><br>This bit is set if pin ESR0 is asserted.<br>$0_B$ No ESR0 trap was requested since this bit was cleared the last time<br>$1_B$ An ESR0 trap was requested since this bit was cleared the last time                                     |
| <b>ESR1T</b> | 12   | rh   | <b>ESR1 Trap Request Flag</b><br>This bit is set if pin ESR1 is asserted.<br>$0_B$ No ESR1 trap was requested since this bit was cleared the last time<br>$1_B$ An ESR1 trap was requested since this bit was cleared the last time                                     |
| <b>ESR2T</b> | 13   | rh   | <b>ESR2 Trap Request Flag</b><br>This bit is set if pin ESR2 is asserted.<br>$0_B$ No ESR2 trap was requested since this bit was cleared the last time<br>$1_B$ An ESR2 trap was requested since this bit was cleared the last time                                     |

## System Control Unit (SCU)

| Field | Bits | Type | Description                                                                                                                                                                                                                                                                   |
|-------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RAT   | 15   | rh   | <b>Register Access Trap Request Flag</b><br>This bit is set a protected register is written by an non-authorized access.<br>$0_B$ No RA trap was requested since this bit was cleared the last time<br>$1_B$ A RA trap was requested since this bit was cleared the last time |
| 0     | 14   | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                       |

## System Control Unit (SCU)

### 8.10.3.7 Register DMPMITCLR

This register contains the software clear option for all sticky status flags of all interrupt and trap request trigger sources of the DMP\_M power domain.

#### DMPMITCLR

#### DMP\_M Interrupt and Trap Clear Register

 SFR (FE98<sub>H</sub>/4C<sub>H</sub>)

 Reset Value: 0000<sub>H</sub>

|           | 15       | 14         | 13         | 12         | 11         | 10         | 9          | 8        | 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0 |
|-----------|----------|------------|------------|------------|------------|------------|------------|----------|------------|------------|------------|------------|------------|------------|------------|---|
| <b>RA</b> | <b>0</b> | <b>ESR</b> | <b>ESR</b> | <b>ESR</b> | <b>STM</b> | <b>STM</b> | <b>GSC</b> | <b>W</b> | <b>WUT</b> | <b>PVC</b> | <b>PVC</b> | <b>PVC</b> | <b>PVC</b> | <b>SWD</b> | <b>SWD</b> |   |
| T         | 0        | 2          | 1          | 0          | 1          | 0          | T          | UI       | I          | 1          | 1          | M          | M          | I2         | I1         |   |
|           | W        | r          | W          | W          | W          | W          | W          | W        | W          | W          | W          | W          | W          | W          | W          | W |

| Field          | Bits | Type | Description                                                                                                               |
|----------------|------|------|---------------------------------------------------------------------------------------------------------------------------|
| <b>SWDI1</b>   | 0    | w    | <b>Clear SWD1 Interrupt Request Flag 1</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit DMPMIT.SWDI1 is cleared      |
| <b>SWDI2</b>   | 1    | w    | <b>Clear SWD Interrupt Request Flag 2</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit DMPMIT.SWDI2 is cleared       |
| <b>PVCM1I1</b> | 2    | w    | <b>Clear PVC_M Interrupt Request Flag 1</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit DMPMIT.PVCM1I1 is cleared   |
| <b>PVCM1I2</b> | 3    | w    | <b>Clear PVC_M Interrupt Request Flag 2</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit DMPMIT.PVCM1I2 is cleared   |
| <b>PVC1I1</b>  | 4    | w    | <b>Clear PVC_1 Interrupt Request Flag 1</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit DMPMIT.PVC1I1 is cleared    |
| <b>PVC1I2</b>  | 5    | w    | <b>Clear PVC_1 Interrupt Request Flag 2</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit DMPMIT.PVC1I2 is cleared    |
| <b>WUTI</b>    | 6    | w    | <b>Clear Wake-up Trim Interrupt Request Flag</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit DMPMIT.WUTI is cleared |
| <b>WUI</b>     | 7    | w    | <b>Clear Wake-up Interrupt Request Flag</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Bit DMPMIT.WUI is cleared       |

## System Control Unit (SCU)

| Field        | Bits | Type | Description                                                                                          |
|--------------|------|------|------------------------------------------------------------------------------------------------------|
| <b>GSC</b>   | 8    | w    | <b>Clear GSC Interrupt Request Flag</b><br>$0_B$ No action<br>$1_B$ Bit DMPMIT.GSCI is cleared       |
| <b>STM0</b>  | 9    | w    | <b>Clear STM0 Interrupt Request Flag</b><br>$0_B$ No action<br>$1_B$ Bit DMPMIT.STM0I is cleared     |
| <b>STM1</b>  | 10   | w    | <b>Clear STM1 Interrupt Request Flag</b><br>$0_B$ No action<br>$1_B$ Bit DMPMIT.STM1I is cleared     |
| <b>ESR0T</b> | 11   | w    | <b>Clear ESR0 Trap Request Flag</b><br>$0_B$ No action<br>$1_B$ Bit DMPMIT.ESR0T is cleared          |
| <b>ESR1T</b> | 12   | w    | <b>Clear ESR1 Trap Request Flag</b><br>$0_B$ No action<br>$1_B$ Bit DMPMIT.ESR1T is cleared          |
| <b>ESR2T</b> | 13   | w    | <b>Clear ESR2 Trap Request Flag</b><br>$0_B$ No action<br>$1_B$ Bit DMPMIT.ESR2T is cleared          |
| <b>RAT</b>   | 15   | w    | <b>Clear Register Access Trap Request Flag</b><br>$0_B$ No action<br>$1_B$ Bit DMPMIT.RAT is cleared |
| <b>0</b>     | 14   | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                              |

## System Control Unit (SCU)

## 8.11 Temperature Compensation Unit

The temperature compensation for the port drivers provides driver output characteristics which are stable (within a certain band of parameter variation) over the specified temperature range.

The temperature compensation oscillator (sensor) provides a reference clock from a free-running temperature-dependent oscillator. An enable trigger is used to define counting cycles where the reference clock pulses are accumulated to build the sensor value TCLR.THCOUNT. The enable trigger is derived from the system clock by a prescaler and a programmable divider (see [Figure 8-30](#)). The value for the programmable divider must be written by the user according to the selected system frequency.

After the count cycle, the resulting count value, i.e. the number of reference clock cycles, is copied to bit field TCLR.THCOUNT. Thus, TCLR.THCOUNT is updated after every count cycle while the temperature compensation is enabled.

Software can compare the temperature-related count value (TCLR.THCOUNT) to several thresholds (temperature levels) in order to determine the control values TCCR.TCC.



**Figure 8-30 Temperature Compensation Clock Generation**

The clock divider is programmed via bit field TCCR.TCDIV. The value that should be used for bit field TCCR.TCDIV can be calculated using the following formula documented in the data sheet.

Generally, temperature compensation is a user-controlled feature. The Temperature Compensation Control Register TCCR provides access to the actual compensation value (generated by the sensor) and allows software control of the pads. During operation the device (i.e. the pads) can be controlled by the value of the on-chip sensor, or by externally provided compensation values. Register TCCR also provides the programmable divider value.

*Note: The relation between the counter value and the temperature can differ between two devices and need to be evaluated for each device individually.*

## System Control Unit (SCU)

*Note: The temperature compensation circuit does not generate temperature compensation values continuously. The idea is, that the SW frequently updates the pad control with the value currently found in the tempcomp register (e.g. by an interrupt generated by a timer). Since temperature is a continuous function it is not relevant, whether the temperature value read is new or the value of a previous measurement.*

## 8.11.1 Temperature Compensation Registers

### 8.11.1.1 TCCR

This register contains the control options.

#### TCCR

#### Temperature Compensation Control Register

ESFR (F1AC<sub>H</sub>/D6<sub>H</sub>)

Reset Value: 0003<sub>H</sub>



| Field | Bits   | Type | Description                                                                                                                                                                                                                                                                                          |
|-------|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TCC   | [1:0]  | rw   | <b>Temperature Compensation Control</b><br>The value which controls the temperature compensation inputs of the pads.<br>00 <sub>B</sub> Maximum reduction = min. driver strength,<br>i.e. very low temperature<br>11 <sub>B</sub> No reduction = max. driver strength,<br>i.e. very high temperature |
| TCDIV | [6:2]  | rw   | <b>Temperature Compensation Clock Divider</b><br>This value adjusts the temperature compensation logic to the selected operating frequency.                                                                                                                                                          |
| TCE   | 7      | rw   | <b>Temperature Compensation Enable</b><br>0 <sub>B</sub> No action<br>1 <sub>B</sub> Enable counting to generate new temperature values.<br>Clearing this bit also stops the temperature compensation oscillator.                                                                                    |
| 0     | [15:8] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                              |

**TCLR**
**Temperature Comp. Level Register**
**ESFR (F0AC<sub>H</sub>/56<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**


| Field          | Bits   | Type | Description                                                                                                                                  |
|----------------|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------|
| <b>THCOUNT</b> | [7:0]  | rh   | <b>Threshold Counter</b><br>Returns the result of the most recent count cycle of the temperature sensor, to be compared with the thresholds. |
| <b>0</b>       | [15:8] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                      |

*Note: The threshold counter will not overflow but rather stop at count 255.*

## System Control Unit (SCU)

## 8.12 Watchdog Timer (WDT)

The following part describes the Watchdog Timer (WDT) and its functionality.

### 8.12.1 Introduction

The Watchdog Timer (WDT) is a secure mechanism to overcome life- and dead-locks. An enabled WDT generates a reset for the system if not serviced in a configured time frame.

### Features

The following list is a summary of the WDT functions:

- 16-bit Watchdog Timer
- Selectable operating frequency:  $f_{IN} / 256$  or  $f_{IN} / 16384$
- Timer overflow error detection
- Individual disable for timer functionality
- Double Reset Detection

**Figure 8-31** provides an overview on the registers of the Watchdog Timer.



**Figure 8-31 Watchdog Timer Register Overview**

### 8.12.2 Overview

The Watchdog Timer (WDT) provides a highly reliable and secure way to detect and recover from software or hardware failure. The WDT helps to abort an accidental malfunction of the XC27x5X in a user-specified time period. When enabled, the WDT will cause the XC27x5X system to be reset if the WDT is not serviced within a user-programmable time period. The CPU must service the WDT within this time interval to prevent the WDT from causing a WDT reset request trigger. Hence, regular service of the WDT confirms that the system is functioning properly.

A further feature of the Watchdog Timer is its reset prewarning operation. Instead of immediately resetting the device on the detection of an error, a prewarning output is given to the system via an interrupt request. This makes it possible to bring the system into a defined and predictable status, before the reset is finally issued.

### 8.12.3 Functional Description

The following part describes all functions of the WDT.

#### 8.12.3.1 Timer Operation

The timer is enabled when instruction ENWDT (Enable Watchdog Timer) is executed correctly.

The WDT uses the input clock  $f_{IN}$  which is equal to the system clock  $f_{sys}$ . A clock divider in front of the WDT timer provides two output frequencies,  $f_{IN} / 256$  and  $f_{IN} / 16384$ . The selection of the counting rate is done via bit **WDTCS.IR**.

#### WDT Periods

The general formula to calculate a Watchdog period is:

$$\text{period} = \frac{(2^{16} - \text{startvalue}) \cdot 256 \cdot 2^{(1 - \text{IR}) \cdot 6}}{f_{IN}} \quad (8.4)$$

The parameter <startvalue> represents either the user-programmable reload value WDTREL.RELV (default value FFFC<sub>H</sub>) for the calculation of the period in Normal Mode or the fixed value FFFF<sub>H</sub> for the calculation of the period in Prewarning Mode.

#### WDT Timer Reload

The counter is reloaded and the prescaler is cleared when one of the following conditions occurs:

- A successful access to register WDTREL
- The WDT is serviced via instruction SRVWDT
- A WDT overflow condition (Prewarning Mode is entered).  
The different reload value for the counter in Prewarning Mode is FFFF<sub>H</sub>.
- The Disable Mode is entered (when instruction DISWDT is executed)
- Upon any reset

#### 8.12.3.2 Timer Modes

The Watchdog Timer provides following modes:

- Normal Mode
- Disable Mode
- Prewarning Mode

**Figure 8-32** provides a state diagram of the different Timer Modes and the transition possibilities. Please refer to the description of the conditions for changing from one mode to the other.



Figure 8-32 State Diagram of the Timer Modes

### Normal Mode

Normal Mode is the default mode after an Application Reset or an Internal Application Reset. Normal Mode can be entered from Disable Mode only when instruction ENWDT is executed.

The timer is loaded with RELV when the Normal Mode is entered, and it starts counting upwards. After reset the timer is loaded with  $\text{FFFC}_H$  (default value of RELV).

It has to be serviced before the counter overflows. Servicing is performed by the CPU via instructions SRVWDT and/or ENWDT.

If the WDT is not serviced before the timer overflows, a system malfunction is assumed, and following operations are done:

- An WDT interrupt trigger is issued
- Prewarning Mode is entered

## System Control Unit (SCU)

- Timer is reloaded with  $\text{FFFF}_H$

### Disable Mode

Disable Mode is provided for applications that do not require the Watchdog Timer function. Disable Mode is entered when instruction DISWDT is executed, either before End-of-Init, if CPUCON1.WDTCTL = 0, or at any time, if CPUCON1.WDTCTL = 1.

The timer is reloaded with the value of WDTREL.RELV when Disable Mode is entered.

A transition from Disable Mode to Normal Mode is performed when instruction ENWDT is executed while CPUCON1.WDTCTL = 1.

### Prewarning Mode

Prewarning Mode is entered always when a Watchdog error is detected. This is an overflow in Normal Mode. Instead of immediately requesting a reset of the device, the WDT enables the system to enter a secure state by issuing the prewarning output before the reset occurs. Receiving the prewarning, the CPU and the system are requested to finish all pending transaction requests and to not generate new ones. The prewarning is signalled via an interrupt. The CPU can recognize the WDT prewarning interrupt via register INTSTAT. After finishing all pending transactions, the CPU should execute the IDLE instruction to stop all further processing before the coming reset.

In Prewarning Mode, the WDT starts counting from  $\text{FFFF}_H$  upwards, and then requests a WDT reset on the overflow of the WDT from  $\text{FFFF}_H$  to  $\text{0000}_H$ . A reset request of the type as configured in **RSTCON1.WDT** can not be avoided. No reset will be requested If RSTCON1.WDT is cleared. The WDT does not react anymore to accesses to its registers and to the ENWDT or DISWDT instruction, nor will it change its state until it is reset.

A further feature of the WDT detects double errors and sets the whole system into a permanent WDT reset. This feature prevents the XC27x5X from executing random wrong code for longer than the occurrence of the overflow, and prevents the XC27x5X from being repeatedly reset by the WDT.

### Double WDT Reset

If the Watchdog induced reset (Application or Internal Application Reset) occurs twice, a severe system malfunction is assumed and the XC27x5X is held in a reset of the type as configured in **RSTCON1.WDT** (or just not) until a Power-on Reset occurs. This prevents the device from being periodically reset if, for instance, connection to the external memory has been lost such that even system initialization could not be performed.

*Note: Triggering a PORST upon a WDT reset will never result in a double WDT overflow.*

If the WDT is configured by RSTCON1.WDT to request an Application Reset or an Internal Application Reset the second reset request will be permanently asserted

## System Control Unit (SCU)

resulting (without any change in the reset configuration) in a permanent reset of the type configured by RSTCON1.WDT.

The information about the first WDT reset request is stored in an internal flag. The internal flag is set when a WDT overflow has occurred in Prewarning Mode and the reset request is generated. If the internal flag is already set then a double WDT reset event has occurred and a permanent reset request is generated.

This internal flag is cleared by any Power-on Reset or when bit **WDTCS.CLRIRF** is set. A correct service of the WDT does not clear this internal flag nor do any access to the WDT related registers or commands. Therefore, if correct WDT-servicing has been done after the first WDT reset and a next WDT reset must not immediately lead to a double error state, application software has to clear the internal flag.

*Note: Regarding the handling of the internal flag It does not matter whether a reset was generated on a WDT reset request or if the reset configuration was changed between the two reset requests.*

*Note: After the double WDT reset request trigger is generated the counter is stopped after the overflow.*

### Port Configuration during WDT Reset

The behavior of the ESRx ports can be defined with respect to the reset type by bit field ESRCFGx.PC. For the coding of PC see **Table 8-6**. This allows to signal the occurrence of a reset.

The configuration of the GPIOS ports depends on the reset type. In case of an Application Reset the pad configuration is unchanged, in case of an Internal Application Reset the ports are configured for input.

### 8.12.3.3 Suspend Mode Support

In an enabled and active debug session, the Watchdog functionality can lead to unintended resets. Therefore, to avoid these resets, the OCDS can control whether the WDT is enabled or disabled (default after reset). This is done via bit CBS\_IOSR.DB.

**Table 8-11 OCDS Behavior of WDT**

| WDTCS.DS | CBS_DBGSR.DBGEN | CBS_IOSR.DB | WDT Action |
|----------|-----------------|-------------|------------|
| 1        | X               | X           | Stopped    |
| 0        | 0               | X           | Running    |
| 0        | 1               | 0           | Stopped    |
| 0        | 1               | 1           | Running    |

## 8.12.4 WDT Kernel Registers

### 8.12.4.1 WDT Reload Register

This register defines the WDT reload value.

**WDTREL**

**WDT Reload Register**

**ESFR (F0C8<sub>H</sub>/64<sub>H</sub>)**

**Reset Value: FFFC<sub>H</sub>**



| Field       | Bits   | Type | Description                                                                                        |
|-------------|--------|------|----------------------------------------------------------------------------------------------------|
| <b>RELV</b> | [15:0] | rw   | <b>Reload Value for the Watchdog Timer</b><br>This bit field defines the reload value for the WDT. |

### 8.12.4.2 WDT Control and Status Register

The Control and Status Register can only be accessed in Secured Mode.

#### WDTCS

#### WDT Control and Status Register

| ESFR ( $F0C6_H/63_H$ ) |    |    |    |    |    |   |   |    |   |   |   |     |    |    |    | Reset Value: $0000_H$ |  |  |  |
|------------------------|----|----|----|----|----|---|---|----|---|---|---|-----|----|----|----|-----------------------|--|--|--|
| 15                     | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6 | 5 | 4 | 3   | 2  | 1  | 0  |                       |  |  |  |
|                        |    |    |    |    |    | 0 |   | IR |   | 0 |   | CLR | PR | DS | OE |                       |  |  |  |
|                        |    |    |    |    |    | r |   | rw |   | r |   | w   | rh | rh | rh |                       |  |  |  |

| Field | Bits | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OE    | 0    | rh   | <b>Overflow Error Status Flag</b><br>$0_B$ No WDT overflow error<br>$1_B$ A WDT overflow error has occurred.<br>This bit is set by hardware when the Watchdog Timer overflows from $FFFF_H$ to $0000_H$ .<br>This bit is only cleared through: <ul style="list-style-type: none"> <li>any Power-on Reset</li> <li>an executed SRVWDT or ENWDT instruction</li> </ul> <i>Note: It is not possible to clear this bit in Prewarning Mode with the SRVWDT or ENWDT instruction.</i> |
| DS    | 1    | rh   | <b>Timer Enable/Disable Status Flag</b><br>$0_B$ Timer is enabled (default after reset)<br>$1_B$ Timer is disabled<br>This bit is cleared when instruction ENWDT was executed and CPUCON1.WDTCTL = 1.<br>This bit is set when instruction DISWDT was executed before EINIT or CPUCON1.WDTCTL = 1.<br><i>Note: ENWDT and DISWDT instruction will be reflected in this bit but in Prewarning Mode the WDT mode is not changed.</i>                                                |
| PR    | 2    | rh   | <b>Prewarning Mode Flag</b><br>$0_B$ Normal Mode (default after reset)<br>$1_B$ Prewarning Mode                                                                                                                                                                                                                                                                                                                                                                                 |

## System Control Unit (SCU)

| Field         | Bits             | Type | Description                                                                                                                                                                                                                                                                                                                                            |
|---------------|------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>CLRIRF</b> | 3                | w    | <b>Clear Internal Reset Flag</b><br>This bit is used to request a clear of the internal flag storing the information about the first WDT reset request.<br>$0_B$ No action<br>$1_B$ Request to clear the internal flag<br>This bit always read as 0.                                                                                                   |
| <b>IR</b>     | 8                | rw   | <b>Input Frequency Request Bit</b><br>$0_B$ Request to set input frequency to $f_{IN} / 16384$<br>$1_B$ Request to set input frequency to $f_{IN} / 256$<br>An update of this bit is taken into account after the next successful execution of instruction SRVWDT or ENWDT, on a write to register WDTREL, and always when the WDT is in Disable Mode. |
| <b>0</b>      | [7:4],<br>[15:9] | r    | <b>Reserved</b><br>Read as 0; should be written with 0;                                                                                                                                                                                                                                                                                                |

### 8.12.4.3 WDT Timer Register

**WDTTIM****WDT Timer Register****ESFR (F0CA<sub>H</sub>/65<sub>H</sub>)****Reset Value: FFFC<sub>H</sub>**

| Field      | Bits   | Type | Description                                                                |
|------------|--------|------|----------------------------------------------------------------------------|
| <b>TIM</b> | [15:0] | rh   | <b>Timer Value</b><br>Reflects the current contents of the Watchdog Timer. |

## 8.13 SCU Trap Generation

The basic trap structure of the SCU is shown in [Figure 8-33](#).



**Figure 8-33 SCU Trap Structure**

If enabled by the corresponding bit in register **TRAPDIS**, a trap is triggered either by a pulse on the incoming trap line, or by a software set of the respective bit in register **TRAPSET**. The trigger sets the respective flag in register **TRAPSTAT** and is gated to one of the trap nodes, selected by the node pointer registers **TRAPNP** and **TRAPNP1**.

The trap flag in register **TRAPSTAT** can be cleared by software by writing to the corresponding bit in register **TRAPCLR**.

If more than one trap source is connected to the same trap (via registers **TRAPNP** and **TRAPNP1**), the requests are combined to one common line.

### Trap Node Assignment

The trap sources of the system can be mapped to three trap nodes by programming the trap node pointer registers **TRAPNP** and **TRAPNP1**. The default assignment of the trap sources to the nodes and their corresponding control register is listed in [Table 8-12](#).

#### 8.13.1 Trap Support

Some of the trap requests are first fed through a sticky flag register in the DMP\_M domain. These flags are set with a trigger and if set trigger the trap generation in the

## System Control Unit (SCU)

DMP\_1.. Please note that the disable control of register TRAPDIS also influences the sticky bit in register **DMPMIT** (see [Section 8.10.3.6](#)).

Which of the trap requests have a sticky flag in register DMPMIT is listed in [Table 8-12](#).

*Note: When servicing an SCU trap request, make sure that all related request flags are cleared after the identified request has been handled. To clear a trap request that is stored in register DMPMIT, first clear the request source of the source, clear the request within DMP\_M via DMPMITCLR, and then clear the request within DMP\_1 via TRAPCLR.*

### 8.13.2 SCU Trap Sources

The SCU receives the trap lines listed in [Table 8-12](#).

**Table 8-12 SCU Trap Request Overview**

| Source of Trap       | Short Name | Sticky Flag in DMPMIT | Default Trap Flag Assignment in Register TFR |
|----------------------|------------|-----------------------|----------------------------------------------|
| Flash Access Trap    | FAT        | ---                   | TFR.ACER (SCU_TRQ0)                          |
| ESR0 Trap            | ESR0T      | yes                   | TFR.SR1 (SCU_TRQ1)                           |
| ESR1 Trap            | ESR1T      | yes                   | TFR.SR1 (SCU_TRQ1)                           |
| ESR2 Trap            | ESR2T      | yes                   | TFR.SR1 (SCU_TRQ1)                           |
| PLL Trap             | OSCWDTT    | ---                   | TFR.SR1 (SCU_TRQ1)                           |
| Register Access Trap | RAT        | yes                   | TFR.ACER (SCU_TRQ0)                          |
| Parity Error Trap    | PET        | ---                   | TFR.ACER (SCU_TRQ0)                          |
| VCO Lock Trap        | VCOLCKT    | ---                   | TFR.SR0 (SCU_TRQ2)                           |
| ECC Error Trap       | ECCT       | ---                   | TFR.ACER (SCU_TRQ0)                          |

### 8.13.3 SCU Trap Control Registers

#### 8.13.3.1 Register TRAPSTAT

This register contains the status flags for all trap request trigger sources of the SCU. For setting and clearing of these status bits by software see registers TRAPSET and TRAPCLR, respectively.

**TRAPSTAT**
**Trap Status Register**
**SFR (FF02<sub>H</sub>/81<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8        | 7               | 6       | 5       | 4               | 3             | 2             | 1             | 0       |
|----|----|----|----|----|----|---|----------|-----------------|---------|---------|-----------------|---------------|---------------|---------------|---------|
|    |    |    |    |    |    |   | ECC<br>T | VCO<br>LCK<br>T | PE<br>T | RA<br>T | OSC<br>WDT<br>T | ESR<br>2<br>T | ESR<br>1<br>T | ESR<br>0<br>T | FA<br>T |
|    |    |    |    |    |    |   | rh       | rh              | rh      | rh      | rh              | rh            | rh            | rh            | rh      |

0

r

| Field | Bits | Type | Description                                                                                                                                                                                                                                                                               |
|-------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FAT   | 0    | rh   | <b>Flash Access Trap Request Flag</b><br>TRAPSTAT.FAT is set when a flash access violation occurs and TRAPDIS.FAT = 0.<br>$0_B$ No FA trap trigger has occurred since this bit was cleared the last time<br>$1_B$ A FA trap trigger has occurred since this bit was cleared the last time |
| ESR0T | 1    | rh   | <b>ESR0 Trap Request Flag</b><br>TRAPSTAT.ESR0T is set when bit DMPMIT.ESR0T is set and TRAPDIS.ESR0T = 0.<br>$0_B$ No ESR0 trap trigger has occurred since this bit was cleared the last time<br>$1_B$ An ESR0 trap trigger has occurred since this bit was cleared the last time        |
| ESR1T | 2    | rh   | <b>ESR1 Trap Request Flag</b><br>TRAPSTAT.ESR1T is set when bit DMPMIT.ESR1T is set and TRAPDIS.ESR1T = 0.<br>$0_B$ No ESR1 trap trigger has occurred since this bit was cleared the last time<br>$1_B$ An ESR1 trap trigger has occurred since this bit was cleared the last time        |

## System Control Unit (SCU)

| Field          | Bits | Type | Description                                                                                                                                                                                                                                                                                                             |
|----------------|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ESR2T</b>   | 3    | rh   | <b>ESR2 Trap Request Flag</b><br>TRAPSTAT.ESR2T is set when bit DMPMIT.ESR0T is set and TRAPDIS.ESR2T = 0.<br>0 <sub>B</sub> No ESR2 trap trigger has occurred since this bit was cleared the last time<br>1 <sub>B</sub> An ESR2 trap trigger has occurred since this bit was cleared the last time                    |
| <b>OSCWDTT</b> | 4    | rh   | <b>OSCWDT Trap Request Flag</b><br>TRAPSTAT.OSCWDTT is set when an OSCWDT emergency event occurs and TRAPDIS.OSCWDTT = 0.<br>0 <sub>B</sub> No OSCWDT trap trigger has occurred since this bit was cleared the last time<br>1 <sub>B</sub> An OSCWDT trap trigger has occurred since this bit was cleared the last time |
| <b>RAT</b>     | 5    | rh   | <b>Register Access Trap Request Flag</b><br>TRAPSTAT.RAT is set when bit DMPMIT.RAT is set and TRAPDIS.RAT = 0.<br>0 <sub>B</sub> No RA trap trigger has occurred since this bit was cleared the last time<br>1 <sub>B</sub> A RA trap trigger has occurred since this bit was cleared the last time                    |
| <b>PET</b>     | 6    | rh   | <b>Parity Error Trap Request Flag</b><br>TRAPSTAT.PET is set when a memory parity error occurs and TRAPDIS.PET = 0.<br>0 <sub>B</sub> No PE trap trigger has occurred since this bit was cleared the last time<br>1 <sub>B</sub> A PE trap trigger has occurred since this bit was cleared the last time                |
| <b>VCOLCKT</b> | 7    | rh   | <b>VCOLCK Trap Request Flag</b><br>TRAPSTAT.VCOLCKT is set when a VCOLCK emergency event occurs and TRAPDIS.VCOLCKT = 0.<br>0 <sub>B</sub> No VCOLCK trap trigger has occurred since this bit was cleared the last time<br>1 <sub>B</sub> A VCOLCK trap trigger has occurred since this bit was cleared the last time   |

## System Control Unit (SCU)

| Field | Bits   | Type | Description                                                                                                                                                                                                                                                                           |
|-------|--------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ECCT  | 8      | rh   | <b>ECC Error Trap Request Flag</b><br>TRAPSTAT.ECCT is set when a memory ECC error occurs and TRAPDIS.ECCT = 0.<br>$0_B$ No ECC trap trigger has occurred since this bit was cleared the last time<br>$1_B$ An ECC trap trigger has occurred since this bit was cleared the last time |
| 0     | [15:9] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                               |

### 8.13.3.2 Register TRAPCLR

This register contains the software clear control for the trap status flags in register TRAPSTAT. Clearing a bit in this register has no effect, reading a bit always returns zero.

#### TRAPCLR

##### Trap Clear Register

 SFR (FE8E<sub>H</sub>/47<sub>H</sub>)

 Reset Value: 0000<sub>H</sub>

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8     | 7         | 6    | 5    | 4         | 3       | 2       | 1       | 0    |
|----|----|----|----|----|----|---|-------|-----------|------|------|-----------|---------|---------|---------|------|
|    |    |    |    |    |    | 0 | ECC T | VCO LCK T | PE T | RA T | OSC WDT T | ESR 2 T | ESR 1 T | ESR 0 T | FA T |

r

| Field   | Bits | Type | Description                                                                                                 |
|---------|------|------|-------------------------------------------------------------------------------------------------------------|
| FAT     | 0    | w    | <b>Clear Flash Access Trap Request Flag</b><br>$0_B$ No action<br>$1_B$ Flag TRAPSTAT.FAT is cleared        |
| ESR0T   | 1    | w    | <b>Clear ESR0 Trap Request Flag</b><br>$0_B$ No action<br>$1_B$ Flag TRAPSTAT.ESR0T is cleared              |
| ESR1T   | 2    | w    | <b>Clear ESR1 Trap Request Flag</b><br>$0_B$ No action<br>$1_B$ Flag TRAPSTAT.ESR1T is cleared              |
| ESR2T   | 3    | w    | <b>Clear ESR2 Trap Request Flag</b><br>$0_B$ No action<br>$1_B$ Flag TRAPSTAT.ESR2T is cleared              |
| OSCWDTT | 4    | w    | <b>Clear OSCWDT Trap Request Flag</b><br>$0_B$ No action<br>$1_B$ Flag TRAPSTAT.OSCWDTT is cleared          |
| RAT     | 5    | w    | <b>Clear Register Access Trap Request Flag</b><br>$0_B$ No action<br>$1_B$ Flag TRAPSTAT.RAT is cleared     |
| PET     | 6    | w    | <b>Clear Parity Error Access Trap Request Flag</b><br>$0_B$ No action<br>$1_B$ Flag TRAPSTAT.PET is cleared |
| VCOLCKT | 7    | w    | <b>Clear VCOLCK Trap Request Flag</b><br>$0_B$ No action<br>$1_B$ Flag TRAPSTAT.VCOLCKT is cleared          |

## System Control Unit (SCU)

| Field | Bits   | Type | Description                                                                                        |
|-------|--------|------|----------------------------------------------------------------------------------------------------|
| ECCT  | 8      | w    | <b>Clear ECC Error Trap Request Flag</b><br>$0_B$ No action<br>$1_B$ Flag TRAPSTAT.ECCT is cleared |
| 0     | [15:9] | r    | <b>Reserved</b><br>Read as 0; should be written with 0                                             |

## System Control Unit (SCU)

### 8.13.3.3 Register TRAPSET

This register contains the software set control for the trap status flags in register TRAPSTAT. Clearing a bit in this register has no effect, reading a bit always returns zero.

#### TRAPSET

##### Trap Set Register

 SFR (FE8C<sub>H</sub>/46<sub>H</sub>)

 Reset Value: 0000<sub>H</sub>

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8     | 7         | 6    | 5    | 4         | 3       | 2       | 1       | 0    |
|----|----|----|----|----|----|---|-------|-----------|------|------|-----------|---------|---------|---------|------|
|    |    |    |    |    |    | 0 | ECC T | VCO LCK T | PE T | RA T | OSC WDT T | ESR 2 T | ESR 1 T | ESR 0 T | FA T |

r

| Field   | Bits | Type | Description                                                                                           |
|---------|------|------|-------------------------------------------------------------------------------------------------------|
| FAT     | 0    | w    | <b>Set Flash Access Trap Request Flag</b><br>$0_B$ No action<br>$1_B$ Flag TRAPSTAT.FAT is set        |
| ESR0T   | 1    | w    | <b>Set ESR0 Trap Request Flag</b><br>$0_B$ No action<br>$1_B$ Flag TRAPSTAT.ESR0T is set              |
| ESR1T   | 2    | w    | <b>Set ESR1 Trap Request Flag</b><br>$0_B$ No action<br>$1_B$ Flag TRAPSTAT.ESR1T is set              |
| ESR2T   | 3    | w    | <b>Set ESR2 Trap Request Flag</b><br>$0_B$ No action<br>$1_B$ Flag TRAPSTAT.ESR2T is set              |
| OSCWDTT | 4    | w    | <b>Set OSCWDT Trap Request Flag</b><br>$0_B$ No action<br>$1_B$ Flag TRAPSTAT.OSCWDTT is set          |
| RAT     | 5    | w    | <b>Set Register Access Trap Request Flag</b><br>$0_B$ No action<br>$1_B$ Flag TRAPSTAT.RAT is set     |
| PET     | 6    | w    | <b>Set Parity Error Access Trap Request Flag</b><br>$0_B$ No action<br>$1_B$ Flag TRAPSTAT.PET is set |
| VCOLCKT | 7    | w    | <b>Set VCOLCK Trap Request Flag</b><br>$0_B$ No action<br>$1_B$ Flag TRAPSTAT.VCOLCKT is set          |

## System Control Unit (SCU)

| Field | Bits   | Type | Description                                                                                  |
|-------|--------|------|----------------------------------------------------------------------------------------------|
| ECCT  | 8      | w    | <b>Set ECC Error Trap Request Flag</b><br>$0_B$ No action<br>$1_B$ Flag TRAPSTAT.ECCT is set |
| 0     | [15:9] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                      |

### 8.13.3.4 Register TRAPDIS

This register contains the software disable control for all trap request trigger sources. Note that the bits ESRxT and RAT in this register also disable the setting of the respective flags in register DMPMIT (see [Section 8.10.1](#)).

#### TRAPDIS

Trap Disable Register

 SFR (FE90<sub>H</sub>/48<sub>H</sub>)

 Reset Value: 009E<sub>H</sub>

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8     | 7         | 6    | 5    | 4         | 3       | 2       | 1       | 0    |
|----|----|----|----|----|----|---|-------|-----------|------|------|-----------|---------|---------|---------|------|
|    |    |    |    |    |    | 0 | ECC T | VCO LCK T | PE T | RA T | OSC WDT T | ESR 2 T | ESR 1 T | ESR 0 T | FA T |
| r  |    |    |    |    |    |   | rw    | rw        | rw   | rw   | rw        | rw      | rw      | rw      | rw   |

| Field   | Bits | Type | Description                                                                                                                      |
|---------|------|------|----------------------------------------------------------------------------------------------------------------------------------|
| FAT     | 0    | rw   | <b>Disable Flash Access Trap Request</b><br>0 <sub>B</sub> FA trap request enabled<br>1 <sub>B</sub> FA trap request disabled    |
| ESR0T   | 1    | rw   | <b>Disable ESR0 Trap Request</b><br>0 <sub>B</sub> ESR0 trap request enabled<br>1 <sub>B</sub> ESR0 trap request disabled        |
| ESR1T   | 2    | rw   | <b>Disable ESR1 Trap Request</b><br>0 <sub>B</sub> ESR1 trap request enabled<br>1 <sub>B</sub> ESR1 trap request disabled        |
| ESR2T   | 3    | rw   | <b>Disable ESR2 Trap Request</b><br>0 <sub>B</sub> ESR2 trap request enabled<br>1 <sub>B</sub> ESR2 trap request disabled        |
| OSCWDTT | 4    | rw   | <b>Disable OSCWDT Trap Request</b><br>0 <sub>B</sub> OSCWDT trap request enabled<br>1 <sub>B</sub> OSCWDT trap request disabled  |
| RAT     | 5    | rw   | <b>Disable Register Access Trap Request</b><br>0 <sub>B</sub> RA trap request enabled<br>1 <sub>B</sub> RA trap request disabled |
| PET     | 6    | rw   | <b>Disable Parity Error Trap Request</b><br>0 <sub>B</sub> PE trap request enabled<br>1 <sub>B</sub> PE trap request disabled    |
| VCOLCKT | 7    | rw   | <b>Disable VCOLCK Trap Request</b><br>0 <sub>B</sub> VCOLCK trap request enabled<br>1 <sub>B</sub> VCOLCK trap request disabled  |

## System Control Unit (SCU)

| Field | Bits   | Type | Description                                                                                                |
|-------|--------|------|------------------------------------------------------------------------------------------------------------|
| ECCT  | 8      | rw   | <b>Disable ECC Error Trap Request</b><br>$0_B$ ECC trap request enabled<br>$1_B$ ECC trap request disabled |
| 0     | [15:9] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                    |

## System Control Unit (SCU)

### 8.13.3.5 Register TRAPNP and TRAPNP1

These register contain the control for the trap node pointers of all SCU trap request trigger sources.

#### TRAPNP

**Trap Node Pointer Register**      **SFR (FE92<sub>H</sub>/49<sub>H</sub>)**      **Reset Value: 8254<sub>H</sub>**

| 15     | 14 | 13 | 12 | 11 | 10     | 9 | 8    | 7 | 6    | 5 | 4    | 3 | 2  | 1 | 0 |
|--------|----|----|----|----|--------|---|------|---|------|---|------|---|----|---|---|
| VCOLCK | PE |    | RA |    | OSCWDT |   | ESR2 |   | ESR1 |   | ESR0 |   | FA |   |   |

rw                rw

| Field | Bits  | Type | Description                                                                                                                                                                                                                                                                                                                                                                 |
|-------|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FA    | [1:0] | rw   | <b>Trap Node Pointer for Flash Access Traps</b><br>TRAPNP.FA selects the trap request output for an enabled FAT trap request.<br>00 <sub>B</sub> Select request output SCU_TRQ0 (TFR.ACER)<br>01 <sub>B</sub> Select request output SCU_TRQ1 (TFR.SR1)<br>10 <sub>B</sub> Select request output SCU_TRQ2 (TFR.SR0)<br>11 <sub>B</sub> Reserved, do not use this combination |
| ESR0  | [3:2] | rw   | <b>Trap Node Pointer for ESR0 Traps</b><br>TRAPNP.ESR0 selects the trap request output for an enabled ESR0 trap request.<br>00 <sub>B</sub> Select request output SCU_TRQ0 (TFR.ACER)<br>01 <sub>B</sub> Select request output SCU_TRQ1 (TFR.SR1)<br>10 <sub>B</sub> Select request output SCU_TRQ2 (TFR.SR0)<br>11 <sub>B</sub> Reserved, do not use this combination      |
| ESR1  | [5:4] | rw   | <b>Trap Node Pointer for ESR1 Traps</b><br>TRAPNP.ESR1 selects the trap request output for an enabled ESR1 trap request.<br>00 <sub>B</sub> Select request output SCU_TRQ0 (TFR.ACER)<br>01 <sub>B</sub> Select request output SCU_TRQ1 (TFR.SR1)<br>10 <sub>B</sub> Select request output SCU_TRQ2 (TFR.SR0)<br>11 <sub>B</sub> Reserved, do not use this combination      |

## System Control Unit (SCU)

| Field         | Bits    | Type | Description                                                                                                                                                                                                                                                                                                                                                                    |
|---------------|---------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ESR2</b>   | [7:6]   | rw   | <b>Trap Node Pointer for ESR2 Traps</b><br>TRAPNP.ESR2 selects the trap request output for an enabled ESR2 trap request.<br>00 <sub>B</sub> Select request output SCU_TRQ0 (TFR.ACER)<br>01 <sub>B</sub> Select request output SCU_TRQ1 (TFR.SR1)<br>10 <sub>B</sub> Select request output SCU_TRQ2 (TFR.SR0)<br>11 <sub>B</sub> Reserved, do not use this combination         |
| <b>OSCWDT</b> | [9:8]   | rw   | <b>Trap Node Pointer for OSCWDT Traps</b><br>TRAPNP.OSCWDT selects the trap request output for an enabled OSCWDT trap request.<br>00 <sub>B</sub> Select request output SCU_TRQ0 (TFR.ACER)<br>01 <sub>B</sub> Select request output SCU_TRQ1 (TFR.SR1)<br>10 <sub>B</sub> Select request output SCU_TRQ2 (TFR.SR0)<br>11 <sub>B</sub> Reserved, do not use this combination   |
| <b>RA</b>     | [11:10] | rw   | <b>Trap Node Pointer for Register Access Traps</b><br>TRAPNP.RA selects the trap request output for an enabled RAT trap request.<br>00 <sub>B</sub> Select request output SCU_TRQ0 (TFR.ACER)<br>01 <sub>B</sub> Select request output SCU_TRQ1 (TFR.SR1)<br>10 <sub>B</sub> Select request output SCU_TRQ2 (TFR.SR0)<br>11 <sub>B</sub> Reserved, do not use this combination |
| <b>PE</b>     | [13:12] | rw   | <b>Trap Node Pointer for Parity Error Traps</b><br>TRAPNP.PE selects the trap request output for an enabled PET trap request.<br>00 <sub>B</sub> Select request output SCU_TRQ0 (TFR.ACER)<br>01 <sub>B</sub> Select request output SCU_TRQ1 (TFR.SR1)<br>10 <sub>B</sub> Select request output SCU_TRQ2 (TFR.SR0)<br>11 <sub>B</sub> Reserved, do not use this combination    |
| <b>VCOLCK</b> | [15:14] | rw   | <b>Trap Node Pointer for VCOLCK Traps</b><br>TRAPNP.VCOLCK selects the trap request output for an enabled VCOLCK trap request.<br>00 <sub>B</sub> Select request output SCU_TRQ0 (TFR.ACER)<br>01 <sub>B</sub> Select request output SCU_TRQ1 (TFR.SR1)<br>10 <sub>B</sub> Select request output SCU_TRQ2 (TFR.SR0)<br>11 <sub>B</sub> Reserved, do not use this combination   |

## System Control Unit (SCU)

**TRAPNP1**
**Trap Node Pointer 1 Register      SFR (FE94<sub>H</sub>/4A<sub>H</sub>)      Reset Value:0000<sub>H</sub>**


| Field      | Bits   | Type | Description                                                                                                                                                                                                                                                                                                                                                                |
|------------|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>ECC</b> | [1:0]  | rw   | <b>Trap Node Pointer for ECC Error Traps</b><br>TRAPNP.ECC selects the trap request output for an enabled ECCT trap request.<br>00 <sub>B</sub> Select request output SCU_TRQ0 (TFR.ACER)<br>01 <sub>B</sub> Select request output SCU_TRQ1 (TFR.SR1)<br>10 <sub>B</sub> Select request output SCU_TRQ2 (TFR.SR0)<br>11 <sub>B</sub> Reserved, do not use this combination |
| <b>0</b>   | [15:2] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                                                                                                    |

## 8.14 Memory Content Protection

For supervising the content of the on-chip memories (Flash memory is not considered here) two mechanisms are provided:

- Error Correction Control
- Parity Checking

**Table 8-13 Available Memory Protection Mechanisms**

| Memory              | Parity | ECC Error Detection | ECC Error Correction | ECC code           |
|---------------------|--------|---------------------|----------------------|--------------------|
| Program SRAM (PS)   | yes    | SED                 | SEC                  | 4 bits per byte    |
| Data SRAM (DS)      | yes    | SED                 | SEC                  | 4 bits per byte    |
| Dual Port SRAM (DP) | yes    | SED                 | SEC                  | 4 bits per byte    |
| Standby RAM (SB)    | yes    | SED                 | SEC                  | 4 bits per byte    |
| USICx SRAM          | yes    | No                  | No                   | -                  |
| MultiCAN SRAM       | no     | SED                 | SEC                  | 7 bits per 32 bits |

## System Control Unit (SCU)

### 8.14.1 Memory Checking Control Register

Only one of both methods can be activated via register MCHKCON. By default the ECC mechanism is selected. After a switch to parity checking all memories needs to be initialized again.

**MCHKCON**
**Memory Checking Control RegisterESFR (F0DC<sub>H</sub>/6E<sub>H</sub>)**

 Reset Value: 0000<sub>H</sub>

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3         | 2         | 1         | 0         |
|----|----|----|----|----|----|---|---|---|---|---|---|-----------|-----------|-----------|-----------|
| 0  |    |    |    |    |    |   |   |   |   |   |   | SEL<br>SB | SEL<br>PS | SEL<br>DS | SEL<br>DP |
| rw |    |    |    |    |    |   |   |   |   |   |   | rw        | rw        | rw        | rw        |

| Field        | Bits   | Type | Description                                                                                                                                                      |
|--------------|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>SELDP</b> | 0      | rw   | <b>Select Memory Check for Dual Port Memory</b><br>$0_B$ ECC checking is selected for dual port memory<br>$1_B$ Parity checking is selected for dual port memory |
| <b>SELDS</b> | 1      | rw   | <b>Select Memory Check for Data SRAM</b><br>$0_B$ ECC checking is selected for data SRAM<br>$1_B$ Parity checking is selected for data SRAM                      |
| <b>SELPS</b> | 2      | rw   | <b>Select Memory Check for Program SRAM</b><br>$0_B$ ECC checking is selected for program SRAM<br>$1_B$ Parity checking is selected for program SRAM             |
| <b>SELSB</b> | 3      | rw   | <b>Select Memory Check for Standby Memory</b><br>$0_B$ ECC checking is selected for Standby memory<br>$1_B$ Parity checking is selected for Standby memory       |
| <b>0</b>     | [15:4] | rw   | <b>Reserved</b><br>Should be written with 0.                                                                                                                     |

### 8.14.2 Parity Error Handling

The on-chip RAM modules check parity information during read accesses and in case of an error a signal can be generated if enabled. These signals are combined and trigger a trap. If a parity error is detected during the trap handler routine a reset request trigger is generated. Registers PEEN and PECON control the behavior of parity errors.



Figure 8-34 Parity Error Control Logic

A parity error, detected while the respective trap flag TFR.ACER is set, generates a reset request. The second error trap cannot be detected and handled by the CPU.

## System Control Unit (SCU)

*Note: The parity trap trigger should activate the Access Error trap (ACER).*

The parity reset request trigger ( $p\_rst\_req$ ) is generated when a parity error trap is request AND flag TFR.ACER is set.

### 8.14.2.1 Parity Software Testing Support

To support testing algorithms for the parity error trap routines a memory parity test logic is implemented for the C166SV2 subsystem memories (PSRAM, DSRAM, and DPRAM) and SBRAM.

The logic is controlled by registers PMTSR and PMTPR. Via bit field PMTPR.PWR a parity value can be writing to any address of every memory. The parity control software test update has to be enabled with bit PMTSR.MTEx for each memory individually. Otherwise a write to the parity control has no effect. With each read access to a memory the parity from the memory parity control is stored in register PMTPR.PRD.

The width and therefore the valid bits in register PMTPR is listed in [Table 8-14](#).

**Table 8-14 Memory Widths**

| Memory                   | Number of Parity Bits | Valid Bits in PWR/PRD |
|--------------------------|-----------------------|-----------------------|
| Dual Port (DP) Memory    | 2                     | PWR[1:0]/PRD[9:8]     |
| Data SRAM (DS) Memory    | 2                     | PWR[1:0]/PRD[9:8]     |
| Program SRAM (PS) Memory | 8                     | PWR[7:0]/PRD[15:8]    |
| Standby RAM (SB) Memory  | 2                     | PWR[1:0]/PRD[9:8]     |

Test software should be located in external memory and should be written in a way that no pre-fetching is performed.

## System Control Unit (SCU)

### 8.14.2.2 Parity Error Registers

The following register enables the functional parity check mechanism.

**PEEN**
**Parity Error Enable Register      ESFR (F0C4<sub>H</sub>/41<sub>H</sub>)      Reset Value: 0000<sub>H</sub>**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8              | 7  | 6              | 5              | 4              | 3              | 2              | 1              | 0              |
|----|----|----|----|----|----|---|----------------|----|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
|    |    |    |    |    |    | 0 | PE<br>EN<br>SB | 0  | PE<br>EN<br>U3 | PE<br>EN<br>U2 | PE<br>EN<br>U1 | PE<br>EN<br>U0 | PE<br>EN<br>PS | PE<br>EN<br>DS | PE<br>EN<br>DP |
|    |    |    |    |    |    |   | rw             | rw | rw             | rw             | rw             | rw             | rw             | rw             | rw             |

| Field         | Bits | Type | Description                                                                                                                                                                                         |
|---------------|------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>PEENDP</b> | 0    | rw   | <b>Parity Error Trap Enable for Dual Port Memory</b><br>$0_B$ No Parity trap is requested for dual port memory parity errors<br>$1_B$ A Parity trap is requested for dual port memory parity errors |
| <b>PEENDS</b> | 1    | rw   | <b>Parity Error Trap Enable for Data SRAM</b><br>$0_B$ No Parity trap is requested for data SRAM parity errors<br>$1_B$ A Parity trap is requested for data SRAM parity errors                      |
| <b>PEENPS</b> | 2    | rw   | <b>Parity Error Trap Enable for Program SRAM</b><br>$0_B$ No Parity trap is requested for program SRAM parity errors<br>$1_B$ A Parity trap is requested for program SRAM parity errors             |
| <b>PEENU0</b> | 3    | rw   | <b>Parity Error Trap Enable for USIC0 Memory</b><br>$0_B$ No Parity trap is requested for USIC0 memory parity errors<br>$1_B$ A Parity trap is requested for USIC0 memory parity errors             |
| <b>PEENU1</b> | 4    | rw   | <b>Parity Error Trap Enable for USIC1 Memory</b><br>$0_B$ No Parity trap is requested for USIC1 memory parity errors<br>$1_B$ A Parity trap is requested for USIC1 memory parity errors             |

## System Control Unit (SCU)

| Field         | Bits         | Type | Description                                                                                                                                                                                   |
|---------------|--------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>PEENU2</b> | 5            | rw   | <b>Parity Error Trap Enable for USIC2 Memory</b><br>$0_B$ No Parity trap is requested for USIC2 memory parity errors<br>$1_B$ A Parity trap is requested for USIC2 memory parity errors       |
| <b>PEENU3</b> | 6            | rw   | <b>Parity Error Trap Enable for USIC3 Memory</b><br>$0_B$ No Parity trap is requested for USIC3 memory parity errors<br>$1_B$ A Parity trap is requested for USIC3 memory parity errors       |
| <b>PEENSB</b> | 8            | rw   | <b>Parity Error Trap Enable for Standby Memory</b><br>$0_B$ No Parity trap is requested for Standby memory parity errors<br>$1_B$ A Parity trap is requested for Standby memory parity errors |
| <b>0</b>      | 7,<br>[15:9] | rw   | <b>Reserved</b><br>Should be written with 0.                                                                                                                                                  |

## **System Control Unit (SCU)**

The following register controls the functional parity check mechanism.

PECON

## Parity Error Control Register ESFR (F0DA<sub>H</sub>/6D<sub>H</sub>)

**Reset Value: 0000<sub>H</sub>**

|     |    |    |    |    |    |   |           |     |           |           |           |           |           |           |           |
|-----|----|----|----|----|----|---|-----------|-----|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8         | 7   | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
| rwh |    |    |    |    |    |   | PEF<br>SB | rwh | PEF<br>U3 | PEF<br>U2 | PEF<br>U1 | PEF<br>U0 | PEF<br>PS | PEF<br>DS | PEF<br>DP |

| Field | Bits | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PEFDP | 0    | rwh  | <p><b>Parity Error Flag for Dual Port Memory</b></p> <p>0<sub>B</sub> No Parity errors have been detected for dual port memory</p> <p>1<sub>B</sub> A Parity error is indicated and can trigger a trap request trigger, if enabled for dual port memory</p> <p>The bit is only set by the enabled parity error from the dual port memory. This bit can only be cleared via software.</p> <p>Writing a zero to this bit does not change the content.</p> <p>Writing a one to this bit does clear the bit.</p> |
| PEFDS | 1    | rwh  | <p><b>Parity Error Flag for Data SRAM</b></p> <p>0<sub>B</sub> No Parity errors have been detected for data SRAM</p> <p>1<sub>B</sub> A Parity error is indicated and can trigger a trap request trigger, if enabled for data SRAM</p> <p>The bit is only set by the enabled parity error from the data SRAM. This bit can only be cleared via software.</p> <p>Writing a zero to this bit does not change the content.</p> <p>Writing a one to this bit does clear the bit.</p>                             |
| PEFPS | 2    | rwh  | <p><b>Parity Error Flag for Program SRAM</b></p> <p>0<sub>B</sub> No Parity errors have been detected for program SRAM</p> <p>1<sub>B</sub> A Parity error is indicated and can trigger a trap request trigger, if enabled for program SRAM</p> <p>The bit is only set by the enabled parity error from the program SRAM. This bit can only be cleared via software.</p> <p>Writing a zero to this bit does not change the content.</p> <p>Writing a one to this bit does clear the bit.</p>                 |

## System Control Unit (SCU)

| Field | Bits | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PEFU0 | 3    | rwh  | <p><b>Parity Error Flag for USIC0 Memory</b></p> <p><math>0_B</math> No Parity errors have been detected for USIC0 memory</p> <p><math>1_B</math> A Parity error is indicated and can trigger a trap request trigger, if enabled for USIC0 memory</p> <p>The bit is only set by the enabled parity error from the USIC0 memory. This bit can only be cleared via software.</p> <p>Writing a zero to this bit does not change the content. Writing a one to this bit does clear the bit.</p> |
| PEFU1 | 4    | rwh  | <p><b>Parity Error Flag for USIC1 Memory</b></p> <p><math>0_B</math> No Parity errors have been detected for USIC1 memory</p> <p><math>1_B</math> A Parity error is indicated and can trigger a trap request trigger, if enabled for USIC1 memory</p> <p>The bit is only set by the enabled parity error from the USIC1 memory. This bit can only be cleared via software.</p> <p>Writing a zero to this bit does not change the content. Writing a one to this bit does clear the bit.</p> |
| PEFU2 | 5    | rwh  | <p><b>Parity Error Flag for USIC2 Memory</b></p> <p><math>0_B</math> No Parity errors have been detected for USIC2 memory</p> <p><math>1_B</math> A Parity error is indicated and can trigger a trap request trigger, if enabled for USIC2 memory</p> <p>The bit is only set by the enabled parity error from the USIC2 memory. This bit can only be cleared via software.</p> <p>Writing a zero to this bit does not change the content. Writing a one to this bit does clear the bit.</p> |
| PEFU3 | 6    | rwh  | <p><b>Parity Error Flag for USIC3 Memory</b></p> <p><math>0_B</math> No Parity errors have been detected for USIC3 memory</p> <p><math>1_B</math> A Parity error is indicated and can trigger a trap request trigger, if enabled for USIC3 memory</p> <p>The bit is only set by the enabled parity error from the USIC3 memory. This bit can only be cleared via software.</p> <p>Writing a zero to this bit does not change the content. Writing a one to this bit does clear the bit.</p> |

## System Control Unit (SCU)

| Field        | Bits         | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------|--------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>PEFSB</b> | 8            | rwh  | <p><b>Parity Error Flag for Standby Memory</b></p> <p>0<sub>B</sub> No Parity errors have been detected for Standby memory</p> <p>1<sub>B</sub> A Parity error is indicated and can trigger a trap request trigger, if enabled for Standby memory</p> <p>The bit is only set by the enabled parity error from the Standby memory. This bit can only be cleared via software.</p> <p>Writing a zero to this bit does not change the content.</p> <p>Writing a one to this bit does clear the bit.</p> |
| <b>0</b>     | 7,<br>[15:9] | rwh  | <p><b>Reserved</b></p> <p>Should be written with 0.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                              |

**PMTPR**
**Parity Memory Test Pattern RegisterESFR (F0E4<sub>H</sub>/72<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**


| Field      | Bits   | Type | Description                                                                                                                                                    |
|------------|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>PRD</b> | [15:8] | rh   | <b>Parity Read Values for Memory Test</b><br>For each byte of a memory module the parity bits generated during the most recent read access are indicated here. |
| <b>PWR</b> | [7:0]  | rw   | <b>Parity Write Values for Memory Test</b><br>For each byte of a memory module the parity bits corresponding to the next write access are stored here.         |

**System Control Unit (SCU)**

*Note: Only one bit MTENxx should be set at the same time in register PMTSR. Otherwise the result of the parity software test is not reliable.*

**PMTSR**
**Parity Memory Test Select RegisterESFR (F0E6<sub>H</sub>/73<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**

|                   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                       | 7 | 6 | 5 | 4 | 3        | 2 | 1                       | 0                       |                         |
|-------------------|----|----|----|----|----|----|---|-------------------------|---|---|---|---|----------|---|-------------------------|-------------------------|-------------------------|
| <b>PES<br/>EN</b> |    |    |    |    |    |    |   | <b>MT<br/>EN<br/>SB</b> |   |   |   |   | <b>0</b> |   | <b>MT<br/>EN<br/>PS</b> | <b>MT<br/>EN<br/>DS</b> | <b>MT<br/>EN<br/>DP</b> |

| Field         | Bits   | Type | Description                                                                                                                                                                                                 |
|---------------|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>MTENDP</b> | 0      | rw   | <b>Memory Test Enable Control for Dual Port Memory</b><br>Controls the test multiplexer for the dual port memory.<br>0 <sub>B</sub> Standard operation<br>1 <sub>B</sub> Test parity bits used (from PMTPR) |
| <b>MTENDS</b> | 1      | rw   | <b>Memory Test Enable Control for Data SRAM</b><br>Controls the test multiplexer for the data SRAM.<br>0 <sub>B</sub> Standard operation<br>1 <sub>B</sub> Test parity bits used (from PMTPR)               |
| <b>MTENPS</b> | 2      | rw   | <b>Memory Test Enable Control for Program SRAM</b><br>Controls the test multiplexer for the program SRAM.<br>0 <sub>B</sub> Standard operation<br>1 <sub>B</sub> Test parity bits used (from PMTPR)         |
| <b>MTENSB</b> | 8      | rw   | <b>Memory Test Enable Control for Standby Memory</b><br>Controls the test multiplexer for the Standby memory.<br>0 <sub>B</sub> Standard operation<br>1 <sub>B</sub> Test parity bits used (from PMTPR)     |
| <b>PESEN</b>  | 15     | rw   | <b>Parity Error Sensitivity Enable</b><br>0 <sub>B</sub> Parity errors have no effect<br>1 <sub>B</sub> Parity errors are indicated and can trigger a trap, if enabled                                      |
| <b>0</b>      | [7:3]  | rw   | <b>Reserved</b><br>Should be written with 0.                                                                                                                                                                |
| <b>0</b>      | [14:9] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                     |

### 8.14.3 ECC Error Handling

The on-chip RAM check ECC information during read accesses and in case of an error a signal is generated. These signals are combined and trigger a trap. Register ECCCON controls the behavior of ECC mechanism.

*Note: Before the ECC logic of an on-chip RAM can be used the first time after a power-on reset operation (before setting its ECCCON enable bit), the corresponding memories must be completely initialized by writing every memory location of it once. Otherwise, unpredictable ECC errors may occur after setting its ECCCON enable bit.*

*Note: When using the autoincrement mode to read the SBRAM and having ECC enabled, it is necessary not only to initialize the used addresses but also the one following the last used address. This problem does not exist if the whole SBRAM is initialized.*

*Note: The handling of Flash ECC errors can not be done in the SCU but in the IMB only.*



Figure 8-35 ECC Error Control Logic

### 8.14.3.1 ECC Registers

#### ECCCON

##### ECC Control Register

**ESFR (F0A8<sub>H</sub>/54<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5  | 4  | 3        | 2        | 1  | 0        |          |          |
|----|----|----|----|----|----|---|---|---|---|----|----|----------|----------|----|----------|----------|----------|
| 0  |    |    |    |    |    |   |   |   |   |    |    | SB<br>EN | MC<br>EN | 0  | PS<br>EN | DS<br>EN | DP<br>EN |
|    |    |    |    |    |    |   |   |   |   | rw | rw | rw       | rw       | rw | rw       | rw       |          |

| Field       | Bits         | Type | Description                                                                                                                               |
|-------------|--------------|------|-------------------------------------------------------------------------------------------------------------------------------------------|
| <b>DPEN</b> | 0            | rw   | <b>Enable for Dual Port Memory</b><br>$0_B$ ECC check is disabled for dual port memory<br>$1_B$ ECC check is enabled for dual port memory |
| <b>DSEN</b> | 1            | rw   | <b>Enable for Data SRAM</b><br>$0_B$ ECC check is disabled for data SRAM<br>$1_B$ ECC check is enabled for data SRAM                      |
| <b>PSEN</b> | 2            | rw   | <b>Enable for Program SRAM</b><br>$0_B$ ECC check is disabled for program SRAM<br>$1_B$ ECC check is enabled for program SRAM             |
| <b>MCEN</b> | 4            | rw   | <b>Enable for MultiCAN Memory</b><br>$0_B$ ECC check is disabled for MultiCAN memory<br>$1_B$ ECC check is enabled for MultiCAN memory    |
| <b>SBEN</b> | 5            | rw   | <b>Enable for Standby Memory</b><br>$0_B$ ECC check is disabled for Standby memory<br>$1_B$ ECC check is enabled for Standby memory       |
| <b>0</b>    | 3,<br>[15:6] | rw   | <b>Reserved</b><br>Should be written with 0.                                                                                              |

## **System Control Unit (SCU)**

ECCSTAT

## ECC Status Register

ESFR (F0AA<sub>H</sub>/55<sub>H</sub>)

**Reset Value: 0000<sub>H</sub>**

|    |    |    |    |    |    |   |   |    |   |    |   |   |   |    |   |    |  |    |  |
|----|----|----|----|----|----|---|---|----|---|----|---|---|---|----|---|----|--|----|--|
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6 | 5  | 4 | 3 | 2 | 1  | 0 |    |  |    |  |
| rh |    |    |    |    |    |   |   | SB |   | MC |   | 0 |   | PS |   | DS |  | DP |  |
|    |    |    |    |    |    |   |   | rh |   | rh |   | r |   | rh |   | rh |  | rh |  |

| Field | Bits         | Type | Description                                                                                                                                              |
|-------|--------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| DP    | 0            | rh   | <b>Dual Port Memory ECC Error Status</b><br>$0_B$ No ECC error was detected for dual port memory<br>$1_B$ An ECC error was detected for dual port memory |
| DS    | 1            | rh   | <b>Data SRAM ECC Error Status</b><br>$0_B$ No ECC error was detected for data SRAM<br>$1_B$ An ECC error was detected for data SRAM                      |
| PS    | 2            | rh   | <b>Program SRAM ECC Error Status</b><br>$0_B$ No ECC error was detected for program SRAM<br>$1_B$ An ECC error was detected for program SRAM             |
| MC    | 4            | rh   | <b>MultiCAN Memory ECC Error Status</b><br>$0_B$ No ECC error was detected for MultiCAN memory<br>$1_B$ An ECC error was detected for MultiCAN memory    |
| SB    | 5            | rh   | <b>Standby Memory ECC Error Status</b><br>$0_B$ No ECC error was detected for Standby memory<br>$1_B$ An ECC error was detected for Standby memory       |
| 0     | 3,<br>[15:6] | rh   | <b>Reserved</b><br>Read as 0.                                                                                                                            |

ECCCLRSTAT

## **ECC Clear Status Register**

ESFR (F0DE<sub>H</sub>/6F<sub>H</sub>)

**Reset Value: 0000<sub>H</sub>**

A horizontal number line with tick marks and labels. The labels are: 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0. Below the line, at position 10, is the label **W**. At position 0, there is a bolded **0**. To the right of the line, there are several groups of labels: **SB**, **MC**, **0**, **PS**, **DS**, and **DP**. Below the line, at positions 5, 4, 3, 2, 1, and 0, are the labels **W**, **W**, **W**, **W**, **W**, and **W** respectively.

| Field | Bits         | Type | Description                                                                                                                                     |
|-------|--------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| DP    | 0            | w    | <b>Clear Dual Port Memory ECC Error Status</b><br>$0_B$ No action<br>$1_B$ Setting this bit clears bit ECCSTAT.DP<br>This bit always read as 0. |
| DS    | 1            | w    | <b>Clear Data SRAM ECC Error Status</b><br>$0_B$ No action<br>$1_B$ Setting this bit clears bit ECCSTAT.DS<br>This bit always read as 0.        |
| PS    | 2            | w    | <b>Clear Program SRAM ECC Error Status</b><br>$0_B$ No action<br>$1_B$ Setting this bit clears bit ECCSTAT.PS<br>This bit always read as 0.     |
| MC    | 4            | w    | <b>Clear MultiCAN Memory ECC Error Status</b><br>$0_B$ No action<br>$1_B$ Setting this bit clears bit ECCSTAT.MC<br>This bit always read as 0.  |
| SB    | 5            | w    | <b>Clear Standby Memory ECC Error Status</b><br>$0_B$ No action<br>$1_B$ Setting this bit clears bit ECCSTAT.SB<br>This bit always read as 0.   |
| 0     | 3,<br>[15:6] | w    | <b>Reserved</b><br>Read as 0.                                                                                                                   |

## 8.15 Register Control

This block handles the register accesses of the SCU and the register access control for all system register that use one of the following protection modes:

- Unprotected Mode
- Write Protection Mode
- Secured Mode

### 8.15.1 Register Access Control

There are some dedicated registers that control critical system functions and modes. These registers are protected by a special register security mechanism so these vital system functions cannot be changed inadvertently after the executing of the EINIT instruction. However, as these registers control central system behavior they need to be accessed during operation. The system control software gets this access via a special security state machine.

If an access violation is detected a trap trigger request is generated.

This security mechanism controls the following security levels which can be configured via register SLC:

- **Unprotected Mode**

No protection is active. Registers can be written at any time. This mode is entered after the Application Reset.

- **Write Protected Mode**

Protected registers are locked against any write access. Write accesses have no effect on these registers. This mode is entered automatically after the EINIT instruction is executed.

- **Secured Mode**

Protected registers can be written using a special command. Registers that are protected by this mode are marked in [Table 8-17](#) as Sec protected.

Access in Secured Mode can be achieved by preceding the intended write access with writing “command 4” to register SLC. After writing “command 4” to register SLC the register protection mechanism remains disabled until the next write to a register on the PD+Bus (SFR, ESFR, XSFR area), i.e. accesses to registers (e.g. CSFR) outside this area do not enable the protection again automatically. Therefore, the lock mechanism after writing “command 4” works differently depending on the register address. Normally one single write access to a protected register is enabled. After this write access the protected registers are locked again automatically. Thereafter, “command 4” has to be written again in order to enable the next write to a protected register. The lock mechanism is not enabled again after a write access to a CSFR register or to a LXBus peripheral register (XLOC area, e.g. USIC, CAN, IMB).

*Note: In Secured Mode the re-enabling of register protection with respect to the write address after “command 4” can lead to an unexpected, not obvious behaviour of*

## System Control Unit (SCU)

*an application:*

*In case the succeeding write to a protected register is delayed due to an interrupt and the ISR itself uses the “command 4” mechanism. After writing “command 4” inside the ISR the protection is expectedly re-installed instead of released and the following write will lead to an ACER trap within the ISR. An ATOMIC instruction, which couples the unlock with the write to the protected register could be used.*

*In case the succeeding write is to a register which does not re-enable the protection mechanism again then the write itself will succeed, but in a following “command 4” sequence the write to SLC register re-locks the protection again and the write to a protected register fails.*

All registers that are equipped with this protection mechanism have additional to normal access parameters (e.g. read only, bit type r or rh) the access limitations defined by the selected security level. Independently of the security level all protected registers can also be read.

### 8.15.1.1 Controlling the Security Level

The two registers Security Level Command register (SLC) and Security Level Status register (SLS) control the security level. The SLC register accepts the commands to control the state machine modifying the security level, while the SLS register shows the actual password, the actual security level, and the state of the state machine.



**Figure 8-36 State Machine for Security Level Controlling**

The following mechanism is used to control the actual security level:

- **Changing the security level**  
can be done by executing the following command sequence:

## System Control Unit (SCU)

“command 0 - command 1 - command 2 - command 3”.

This sequence establishes a new security level and/or a new password.

**Table 8-15 Commands for Security Level Control**

| Command   | Definition                                                         | Note              |
|-----------|--------------------------------------------------------------------|-------------------|
| Command 0 | AAAA <sub>H</sub>                                                  |                   |
| Command 1 | 5554 <sub>H</sub>                                                  |                   |
| Command 2 | 96 <sub>H</sub> + <sup>1)</sup> <inverse password>                 |                   |
| Command 3 | 000 <sub>B</sub> + <new level> + 000 <sub>B</sub> + <new password> |                   |
| Command 4 | 8E <sub>H</sub> + <inverse password>                               | Secured Mode only |

<sup>1)</sup> '+' denotes a bit field concatenation

*Note: It is recommended to lock all command sequences with an atomic sequence.*

## 8.15.2 Register Protection Registers

### Register SLC

This register is the interface for the protection commands.

#### SLC

#### Security Level Command RegisterESFR (F0C0<sub>H</sub>/60<sub>H</sub>)

Reset Value: 0000<sub>H</sub>



| Field   | Bits   | Type | Description                                                                                                                      |
|---------|--------|------|----------------------------------------------------------------------------------------------------------------------------------|
| COMMAND | [15:0] | rw   | <b>Security Level Control Command</b><br>The commands to control the security level must be written to this register (see table) |

## Register SLS

This register monitors the status of the register protection.

### SLS

#### Security Level Status Register ESFR (F0C2<sub>H</sub>/61<sub>H</sub>)

Reset Value: 0000<sub>H</sub>

| 15           | 14 | 13        | 12 | 11       | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3               | 2 | 1 | 0 |
|--------------|----|-----------|----|----------|----|---|---|---|---|---|---|-----------------|---|---|---|
|              |    |           |    |          |    |   |   |   |   |   |   |                 |   |   |   |
| <b>STATE</b> |    | <b>SL</b> |    | <b>0</b> |    |   |   |   |   |   |   | <b>PASSWORD</b> |   |   |   |
| rh           |    | rh        |    | r        |    |   |   |   |   |   |   | rh              |   |   |   |

| Field           | Bits    | Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------|---------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>PASSWORD</b> | [7:0]   | rh   | <b>Current Security Control Password</b><br>Default after reset = 00 <sub>H</sub>                                                                                                                                                                                                                                                                                                                                                    |
| <b>SL</b>       | [12:11] | rh   | <b>Security Level</b> <sup>1)</sup><br>00 <sub>B</sub> Unprotected Mode (default)<br>01 <sub>B</sub> Secured Mode<br>10 <sub>B</sub> Reserved, Do not use this combination<br>11 <sub>B</sub> Write Protected Mode                                                                                                                                                                                                                   |
| <b>STATE</b>    | [15:13] | rh   | <b>Current State of Switching State Machine</b><br>000 <sub>B</sub> Awaiting command 0 or command 4 (default)<br>001 <sub>B</sub> Awaiting command 1<br>010 <sub>B</sub> Awaiting command 2<br>011 <sub>B</sub> Awaiting new security level and password<br>100 <sub>B</sub> Next access granted in Secured Mode<br>101 <sub>B</sub> Reserved, do not use this combination<br>11X <sub>B</sub> Reserved, do not use this combination |
| <b>0</b>        | [10:8]  | r    | <b>Reserved</b><br>Read as 0; should be written with 0;                                                                                                                                                                                                                                                                                                                                                                              |

<sup>1)</sup> While the security level is “unprotected” after reset, it changes to “write protected” after the execution of instruction EINIT.

## System Control Unit (SCU)

## 8.16 Miscellaneous System Registers

This chapter acts as container for various register that are not connected to one specific application topic.

### 8.16.1 System Registers

#### 8.16.1.1 System Control Register

The following register serve several different system tasks.

**SYSCON1**
**System Control 1 Register**
**SFR (FF4C<sub>H</sub>/A6<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**


| Field  | Bits             | Type | Description                                                                                                                                                                                                                                                                                         |
|--------|------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OCDSEN | 2                | rw   | <b>OCDSEN</b><br><b>OCDS/Cerberus Enable</b><br>$0_B$ OCDS and Cerberus are still in reset state<br>$1_B$ OCDS and Cerberus are operable                                                                                                                                                            |
| GLCCST | 3                | rw   | <b>Global CAPCOM Start</b><br>This bit starts all CAPCOM units synchronously if enabled.<br>$0_B$ CAPCOM timer start is controlled locally in each unit<br>$1_B$ All CAPCOM timers are started synchronously<br>This bit needs to be cleared via software before setting starts a new CAPCOM start. |
| 0      | [1:0],<br>[15:4] | r    | <b>Reserved</b><br>Read as 0; should be written with 0.                                                                                                                                                                                                                                             |

## 8.16.2 Identification Block

For identification of the most important silicon parameters a set of identification registers is defined that provide information on the chip manufacturer, the chip type and its properties.

### 8.16.2.1 Identification Registers

#### Register IDMANUF

This register contains information about the manufacturer.

##### IDMANUF

##### Manufacturer Identification Register



| Field        | Bits   | Type | Description                                                                                                         |
|--------------|--------|------|---------------------------------------------------------------------------------------------------------------------|
| <b>DEPT</b>  | [4:0]  | r    | <b>Department</b><br>Indicates the department within Infineon.<br>00 <sub>H</sub> AIM MC                            |
| <b>MANUF</b> | [15:5] | r    | <b>Manufacturer</b><br>This is the JEDEC normalized manufacturer code.<br>0C1 <sub>H</sub> Infineon Technologies AG |

## Register IDCHIP

This register contains information about the device.

### IDCHIP

**Chip Identification Register      ESFR (F07C<sub>H</sub>/3E<sub>H</sub>)      Reset Value: XXXX<sub>H</sub>**



| Field           | Bits   | Type | Description                                                                                                                  |
|-----------------|--------|------|------------------------------------------------------------------------------------------------------------------------------|
| <b>Revision</b> | [7:0]  | r    | <b>Device Revision Code</b><br>Identifies the device step.<br>Please refer to the data sheet for the device specific value.  |
| <b>CHIPID</b>   | [15:8] | r    | <b>Device Identification</b><br>Identifies the device name.<br>Please refer to the data sheet for the device specific value. |

## Register IDMEM

This register contains information about the program memory.

### IDMEM

#### Program Memory Identification Register

**ESFR (F07A<sub>H</sub>/3D<sub>H</sub>)**

**Reset Value: 3XXX<sub>H</sub>**



| Field       | Bits    | Type | Description                                                                                                                                                                                                     |
|-------------|---------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>SIZE</b> | [11:0]  | rw   | <b>Size of on-chip Program Memory</b><br>The size of the implemented program memory in terms of 4 K blocks, i.e. memory size = <SIZE>*4 Kbyte.<br>Please refer to the data sheet for the device specific value. |
| <b>TYPE</b> | [15:12] | r    | <b>Type of on-chip Program Memory</b><br>Identifies the memory type on this silicon.<br>Please refer to the data sheet for the device specific value.                                                           |

**System Control Unit (SCU)**
**Register IDPROG**

This register contains information about the flash programming voltage.

**IDPROG**
**Programming Voltage Id. Register**
**ESFR (F078<sub>H</sub>/3C<sub>H</sub>)**
**Reset Value: 1313<sub>H</sub>**


| Field          | Bits   | Type | Description                                                                                                                                                                                                                                   |
|----------------|--------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>PROGVDD</b> | [7:0]  | r    | <b>Programming VDD Voltage</b><br>The voltage of the standard power supply required to program or erase (if applicable) the on-chip program memory.<br>Please refer to the data sheet for the device specific value.                          |
| <b>PROGVPP</b> | [15:8] | r    | <b>Programming VPP Voltage</b><br>The voltage of the special programming power supply (if existent) required to program or erase (if applicable) the on-chip program memory.<br>Please refer to the data sheet for the device specific value. |

## 8.16.3 Marker Memory

### 8.16.3.1 Marker Memory Registers

The marker memory consists of following SFRs located in the DMP\_M for free usage of the user software.

#### MKMEM0

**Marker Memory 0 Register**      **SFR (FED0<sub>H</sub>/68<sub>H</sub>)**      **Reset Value: 0000<sub>H</sub>**

#### MKMEM1

**Marker Memory 1 Register**      **SFR (FED2<sub>H</sub>/69<sub>H</sub>)**      **Reset Value: 0000<sub>H</sub>**



| Field         | Bits   | Type | Description           |
|---------------|--------|------|-----------------------|
| <b>MARKER</b> | [15:0] | rw   | <b>Marker Content</b> |

## System Control Unit (SCU)

## 8.17 SCU Register Addresses

The SCU registers are within the (E)SFR space of the XC27x5X. Therefore, their specified addresses equal an offset from zero.

**Table 8-16 Registers Address Space**

| Module | Base Address         | End Address          | Note |
|--------|----------------------|----------------------|------|
| SCU    | 00 0000 <sub>H</sub> | 00 FFFE <sub>H</sub> |      |

## SCU Register Overview

**Table 8-17 Register Overview of SCU**

| Short Name       | Register Long Name                               | Offset Addr.      | Protection <sup>1)</sup> | Reset <sup>2)</sup> |
|------------------|--------------------------------------------------|-------------------|--------------------------|---------------------|
| <b>WUOSCCON</b>  | Wake-up OSC Control Register                     | F1AE <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>HPOSCCON</b>  | High Precision Oscillator Configuration Register | F1B4 <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>PLLOSCCON</b> | PLL Control Register                             | F1B6 <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>PLLSTAT</b>   | PLL Status Register                              | F0BC <sub>H</sub> | -                        | Power-on Reset      |
| <b>STATCLR1</b>  | PLL Status Clear 1 Register                      | F0E2 <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>PLLCON0</b>   | PLL Configuration 0 Register                     | F1B8 <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>PLLCON1</b>   | PLL Configuration 1 Register                     | F1BA <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>PLLCON2</b>   | PLL Configuration 2 Register                     | F1BC <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>PLLCON3</b>   | PLL Configuration 3 Register                     | F1BE <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>SYSCON0</b>   | System Configuration 0 Register                  | FF4A <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>STATCLR0</b>  | Status Clear 0 Register                          | F0E0 <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>RTCCLKCON</b> | RTC Clock Control Register                       | FF4E <sub>H</sub> | Sec                      | Power-on Reset      |

## System Control Unit (SCU)

Table 8-17 Register Overview of SCU

| Short Name           | Register Long Name                   | Offset Addr.      | Protection <sup>1)</sup> | Reset <sup>2)</sup> |
|----------------------|--------------------------------------|-------------------|--------------------------|---------------------|
| <b>EXTCON</b>        | External Clock Control Register      | FF5E <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>STMREL</b>        | STM Reload Register                  | F1A8 <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>STMCON</b>        | STM Control Register                 | F1AA <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>WUTREL</b>        | Wake-up Timer Reload Register        | F0B0 <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>WUCR</b>          | Wake-up Control Register             | F1B0 <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>RSTSTAT0</b>      | Reset Status 0 Register              | F0B2 <sub>H</sub> | -                        | Power-on Reset      |
| <b>RSTSTAT1</b>      | Reset Status 1 Register              | F0B4 <sub>H</sub> | -                        | Power-on Reset      |
| <b>RSTSTAT2</b>      | Reset Status 2 Register              | F0B6 <sub>H</sub> | -                        | Power-on Reset      |
| <b>RSTCON0</b>       | Reset Configuration 0 Register       | F0B8 <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>RSTCON1</b>       | Reset Configuration 1 Register       | F0BA <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>RSTCNTCON</b>     | Reset Counter Configuration Register | F1B2 <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>SWRSTCON</b>      | SW Reset Control Register            | F0AE <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>ESREXCON1</b>     | ESR 1 External Control Register      | FF32 <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>ESREXCON2</b>     | ESR 2 External Control Register      | FF34 <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>ESREXSTAT1</b>    | ESR 1 External Status Register       | FF36 <sub>H</sub> | -                        | Power-on Reset      |
| <b>ESREXSTAT2</b>    | ESR 2 External Status Register       | FF38 <sub>H</sub> | -                        | Power-on Reset      |
| <b>CLRESREXSTAT1</b> | Clear ESR 1 External Status Register | FF3A <sub>H</sub> | Sec                      | Power-on Reset      |

## System Control Unit (SCU)

Table 8-17 Register Overview of SCU

| Short Name           | Register Long Name                   | Offset Addr.        | Protection <sup>1)</sup> | Reset <sup>2)</sup> |
|----------------------|--------------------------------------|---------------------|--------------------------|---------------------|
| <b>CLRESREXSTAT2</b> | Clear ESR 2 External Status Register | F <sub>FF3C_H</sub> | Sec                      | Power-on Reset      |
| <b>ESRCFG0</b>       | ESR 0 Configuration Register         | F <sub>100_H</sub>  | Sec                      | Power-on Reset      |
| <b>ESRCFG1</b>       | ESR 1 Configuration Register         | F <sub>102_H</sub>  | Sec                      | Power-on Reset      |
| <b>ESRCFG2</b>       | ESR 2 Configuration Register         | F <sub>104_H</sub>  | Sec                      | Power-on Reset      |
| <b>ESRDAT</b>        | ESR Data Register                    | F <sub>106_H</sub>  | Sec                      | Power-on Reset      |
| <b>SWDCON0</b>       | SWD Control 0 Register               | F <sub>080_H</sub>  | Sec                      | Power-on Reset      |
| <b>SWDCON1</b>       | SWD Control 1 Register               | F <sub>082_H</sub>  | Sec                      | Power-on Reset      |
| <b>PVC1CON0</b>      | PVC_1 Control for Step 0 Register    | F <sub>014_H</sub>  | Sec                      | Power-on Reset      |
| <b>PVCMCON0</b>      | PVC_M Control for Step 0 Register    | F <sub>1E4_H</sub>  | Sec                      | Power-on Reset      |
| <b>EVR1CON0</b>      | EVR_1 Control 0 Register             | F <sub>088_H</sub>  | Sec                      | Power-on Reset      |
| <b>EVR1SET15VHP</b>  | EVR_1 Setting for 1.5V HP Register   | F <sub>09E_H</sub>  | Sec                      | Power-on Reset      |
| <b>EVRMCON0</b>      | EVR_M Control 0 Register             | F <sub>084_H</sub>  | Sec                      | Power-on Reset      |
| <b>EVRMCON1</b>      | EVR_M Control 1 Register             | F <sub>086_H</sub>  | Sec                      | Power-on Reset      |
| <b>EVRMSET15VHP</b>  | EVR_M Setting for 1.5V HP Register   | F <sub>096_H</sub>  | Sec                      | Power-on Reset      |
| <b>GSCSWREQ</b>      | GSC SW Request Register              | F <sub>F14_H</sub>  | Sec                      | Application Reset   |
| <b>GSCEN</b>         | GSC Enable Register                  | F <sub>F16_H</sub>  | Sec                      | Application Reset   |
| <b>GSCSTAT</b>       | GSC Status Register                  | F <sub>F18_H</sub>  | -                        | Application Reset   |

## System Control Unit (SCU)

Table 8-17 Register Overview of SCU

| Short Name          | Register Long Name                                  | Offset Addr.      | Protection <sup>1)</sup> | Reset <sup>2)</sup> |
|---------------------|-----------------------------------------------------|-------------------|--------------------------|---------------------|
| <b>GSCPERSTATED</b> | GSC Peripheral Status Enable Register               | FF04 <sub>H</sub> | Sec                      | Application Reset   |
| <b>GSCPERSTAT</b>   | GSC Peripheral Status Register                      | FF1A <sub>H</sub> | -                        | Application Reset   |
| <b>STSTAT</b>       | Start-up Status Register                            | F1E0 <sub>H</sub> | -                        | Application Reset   |
| <b>EXISEL</b>       | External Interrupt Input Select Register            | F1A0 <sub>H</sub> | Sec                      | Application Reset   |
| <b>EXICON0</b>      | External Interrupt Input Trigger Control 0 Register | F030 <sub>H</sub> | Sec                      | Application Reset   |
| <b>EXICON1</b>      | External Interrupt Input Trigger Control 1 Register | F032 <sub>H</sub> | Sec                      | Application Reset   |
| <b>EXICON2</b>      | External Interrupt Input Trigger Control 2 Register | F034 <sub>H</sub> | Sec                      | Application Reset   |
| <b>EXICON3</b>      | External Interrupt Input Trigger Control 3 Register | F036 <sub>H</sub> | Sec                      | Application Reset   |
| <b>EXOCON0</b>      | External Output Trigger Control 0 Register          | FE30 <sub>H</sub> | Sec                      | Application Reset   |
| <b>EXOCON1</b>      | External Output Trigger Control 1 Register          | FE32 <sub>H</sub> | Sec                      | Application Reset   |
| <b>EXOCON2</b>      | External Output Trigger Control 2 Register          | FE34 <sub>H</sub> | Sec                      | Application Reset   |
| <b>EXOCON3</b>      | External Output Trigger Control 3 Register          | FE36 <sub>H</sub> | Sec                      | Application Reset   |
| <b>INTSTAT</b>      | Interrupt Status Register                           | FF00 <sub>H</sub> | -                        | Application Reset   |
| <b>INTCLR</b>       | Interrupt Clear Register                            | FE82 <sub>H</sub> | Sec                      | Application Reset   |
| <b>INTSET</b>       | Interrupt Set Register                              | FE80 <sub>H</sub> | Sec                      | Application Reset   |
| <b>INTDIS</b>       | Interrupt Disable Register                          | FE84 <sub>H</sub> | Sec                      | Application Reset   |
| <b>INTNP0</b>       | Interrupt Node Pointer 0 Register                   | FE86 <sub>H</sub> | Sec                      | Application Reset   |

## System Control Unit (SCU)

Table 8-17 Register Overview of SCU

| Short Name       | Register Long Name                        | Offset Addr.      | Protection <sup>1)</sup> | Reset <sup>2)</sup> |
|------------------|-------------------------------------------|-------------------|--------------------------|---------------------|
| <b>INTNP1</b>    | Interrupt Node Pointer 1 Register         | FE88 <sub>H</sub> | Sec                      | Application Reset   |
| <b>DMPMIT</b>    | DMP_M Interrupt and Trap Trigger Register | FE96 <sub>H</sub> | -                        | Power-on Reset      |
| <b>DMPMITCLR</b> | DMP_M Interrupt and Trap Clear Register   | FE98 <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>TCCR</b>      | Temperature Compensation Control Register | F1AC <sub>H</sub> | Sec                      | Application Reset   |
| <b>TCLR</b>      | Temperature Compensation Level Register   | F0AC <sub>H</sub> | Sec                      | Application Reset   |
| <b>WDTREL</b>    | WDT Reload Register                       | F0C8 <sub>H</sub> | Sec                      | Application Reset   |
| <b>WDTCS</b>     | WDT Control and Status Register           | F0C6 <sub>H</sub> | Sec                      | Application Reset   |
| <b>WDTTIM</b>    | WDT Timer Register                        | F0CA <sub>H</sub> | Sec                      | Application Reset   |
| <b>TRAPSTAT</b>  | Trap Status Register                      | FF02 <sub>H</sub> | -                        | Power-on Reset      |
| <b>TRAPCLR</b>   | Trap Clear Register                       | FE8E <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>TRAPSET</b>   | Trap Set Register                         | FE8C <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>TRAPDIS</b>   | Trap Disable Register                     | FE90 <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>TRAPNP</b>    | Trap Node Pointer Register                | FE92 <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>TRAPNP1</b>   | Trap Node Pointer 1 Register              | FE94 <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>MCHKCON</b>   | Memory Checking Control Register          | F0DC <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>PEEN</b>      | Parity Error Enable Register              | F0C4 <sub>H</sub> | Sec                      | Power-on Reset      |

## System Control Unit (SCU)

Table 8-17 Register Overview of SCU

| Short Name        | Register Long Name                          | Offset Addr.      | Protection <sup>1)</sup> | Reset <sup>2)</sup> |
|-------------------|---------------------------------------------|-------------------|--------------------------|---------------------|
| <b>PECON</b>      | Parity Error Control Register               | F0DA <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>PMTPR</b>      | Parity Memory Test Pattern Register         | F0E4 <sub>H</sub> | Sec                      | Application Reset   |
| <b>PMTSR</b>      | Parity Memory Test Select Register          | F0E6 <sub>H</sub> | Sec                      | Application Reset   |
| <b>ECCCON</b>     | ECC Control Register                        | F0A8 <sub>H</sub> | Sec                      | Application Reset   |
| <b>ECCSTAT</b>    | ECC Status Register                         | F0AA <sub>H</sub> | -                        | Application Reset   |
| <b>ECCCLRSTAT</b> | ECC Clear Status Register                   | F0DE <sub>H</sub> | Sec                      | Application Reset   |
| <b>SLC</b>        | Security Level Command Register             | F0C0 <sub>H</sub> | -                        | Application Reset   |
| <b>SLS</b>        | Security Level Status Register              | F0C2 <sub>H</sub> | -                        | Application Reset   |
| <b>SYSCON1</b>    | System Control 1 Register                   | FF4C <sub>H</sub> | Sec                      | Application Reset   |
| <b>IDMANUF</b>    | Manufacturer Identification Register        | F07E <sub>H</sub> | -                        | Power-on Reset      |
| <b>IDCHIP</b>     | Chip Identification Register                | F07C <sub>H</sub> | -                        | Power-on Reset      |
| <b>IDMEM</b>      | Program Memory Identification Register      | F07A <sub>H</sub> | -                        | Power-on Reset      |
| <b>IDPROG</b>     | Programming Voltage Identification Register | F078 <sub>H</sub> | -                        | Power-on Reset      |
| <b>MKMEM0</b>     | Marker Memory 0 Register                    | FED0 <sub>H</sub> | Sec                      | Power-on Reset      |
| <b>MKMEM1</b>     | Marker Memory 1 Register                    | FED2 <sub>H</sub> | Sec                      | Power-on Reset      |

<sup>1)</sup> Register write protection mechanism: "Sec" = register security mechanism, "-" = always accessible (no protection), otherwise no access is possible.

<sup>2)</sup> Reset types are defined in [Chapter 8.4.1.2](#).

## 8.18 Implementation

This section shows the connections of the module to the system.

### 8.18.1 Clock Generation Unit

The following table shows the input connection of the Clock Generation Unit (see [Chapter 8.1](#)).

**Table 8-18 CGU Input Connection**

| Input  | Connected to |
|--------|--------------|
| XTAL 1 | XTAL 1       |
| XTAL 2 | XTAL 2       |
| CLKIN1 | Port 2.9     |
| CLKIN2 | Port 4.4     |

### 8.18.2 External Service Requests (ESR)

The availability of pins  $\overline{\text{ESR1}}$  and  $\overline{\text{ESR2}}$  is device and package dependent. It is described in the data sheet.

## System Control Unit (SCU)

### 8.18.3 External Request Unit (ERU)

The connections of the ERU (see [Chapter 8.9](#)) are device specific. In the following the connections of the ERU in XC27x5X are described.

#### 8.18.3.1 ERU Input Connections

The following figure shows the ERU input connections, either directly with pins or via communication modules, such as USIC or MultiCAN. These communication modules provide their input signals (e.g. CAN receive input, or USIC data, clock, or control inputs) that have been selected in these modules.



**Figure 8-37 ERU Inputs Overview**

**System Control Unit (SCU)**

The following table describes the ERU input connections for the ERSx stages. The selection is defined by the bit fields in register **EXISEL**.

**Table 8-19 ERSx Connections in XC27x5X**

| Input | from/to Module | I/O to ERSx | Can be used to/as |
|-------|----------------|-------------|-------------------|
|-------|----------------|-------------|-------------------|

**ERS0 Inputs**

|         |             |  |              |
|---------|-------------|--|--------------|
| ERU_0A0 | P2.1        |  | ERS0 input A |
| ERU_0A1 | ESR1        |  |              |
| ERU_0A2 | U0C0_DX0INS |  |              |
| ERU_0A3 | U0C0_DX2INS |  |              |
| ERU_0B0 | P1.0        |  | ERS0 input B |
| ERU_0B1 | P5.13       |  |              |
| ERU_0B2 | U0C1_DX0INS |  |              |
| ERU_0B3 | U0C1_DX2INS |  |              |

**ERS1 Inputs**

|         |                  |  |              |
|---------|------------------|--|--------------|
| ERU_1A0 | P2.2             |  | ERS1 input A |
| ERU_1A1 | ESR2             |  |              |
| ERU_1A2 | U1C0_DX0INS      |  |              |
| ERU_1A3 | U1C0_DX2INS      |  |              |
| ERU_1B0 | P1.1             |  | ERS1 input B |
| ERU_1B1 | MultiCAN_CAN4INS |  |              |
| ERU_1B2 | U1C1_DX0INS      |  |              |
| ERU_1B3 | U1C1_DX2INS      |  |              |

**ERS2 Inputs**

|         |                  |  |              |
|---------|------------------|--|--------------|
| ERU_2A0 | P1.2             |  | ERS2 input A |
| ERU_2A1 | MultiCAN_CAN3INS |  |              |
| ERU_2A2 | U2C0_DX0INS      |  |              |
| ERU_2A3 | U2C0_DX2INS      |  |              |

## System Control Unit (SCU)

**Table 8-19 ERSx Connections in XC27x5X (cont'd)**

| Input   | from/to Module   | I/O to ERSx | Can be used to/as |
|---------|------------------|-------------|-------------------|
| ERU_2B0 | U2C0_DX1INS      | I           | ERS2 input B      |
| ERU_2B1 | MultiCAN_CAN2INS | I           |                   |
| ERU_2B2 | U2C1_DX0INS      | I           |                   |
| ERU_2B3 | U2C1_DX2INS      | I           |                   |

**ERS3 Inputs**

|         |                  |   |              |
|---------|------------------|---|--------------|
| ERU_3A0 | P1.3             | I | ERS3 input A |
| ERU_3A1 | MultiCAN_CAN1INS | I |              |
| ERU_3A2 | GPT12E_T3OUT     | I |              |
| ERU_3A3 | 0                | I |              |
| ERU_3B0 | U1C0_DX1INS      | I | ERS3 input B |
| ERU_3B1 | MultiCAN_CAN0INS | I |              |
| ERU_3B2 | 0                | I |              |
| ERU_3B3 | 0                | I |              |

**System Control Unit (SCU)**

### 8.18.3.2 Output Gating Unit (OGUy)

The following table describes the peripheral trigger connections for the OGUy stages.

**Table 8-20 OGUy Peripheral Trigger Connections in XC27x5X**

| Input | from/to Module | I/O to OGUy | Can be used to/as |
|-------|----------------|-------------|-------------------|
|-------|----------------|-------------|-------------------|

#### OGU0 Inputs

|           |              |   |                              |
|-----------|--------------|---|------------------------------|
| ERU_OGU01 | CCU60_MCM_ST | I | Peripheral triggers for OGU0 |
| ERU_OGU02 | CCU60_T13_PM | I |                              |
| ERU_OGU03 | CC2_28       | I |                              |

#### OGU1 Inputs

|           |              |   |                              |
|-----------|--------------|---|------------------------------|
| ERU_OGU11 | CCU61_MCM_ST | I | Peripheral triggers for OGU1 |
| ERU_OGU12 | CCU61_T13_PM | I |                              |
| ERU_OGU13 | CC2_29       | I |                              |

#### OGU2 Inputs

|           |              |   |                              |
|-----------|--------------|---|------------------------------|
| ERU_OGU21 | CCU62_MCM_ST | I | Peripheral triggers for OGU2 |
| ERU_OGU22 | CCU62_T13_PM | I |                              |
| ERU_OGU23 | CC2_30       | I |                              |

#### OGU3 Inputs

|           |              |   |                              |
|-----------|--------------|---|------------------------------|
| ERU_OGU31 | CCU63_MCM_ST | I | Peripheral triggers for OGU3 |
| ERU_OGU32 | CCU63_T13_PM | I |                              |
| ERU_OGU33 | CC2_31       | I |                              |

## System Control Unit (SCU)

### 8.18.3.3 ERU Output Connections

The following table describes the connections of the ERU output signals for gating or triggering other module functions, as well as the connections to the interrupt control registers.

**Table 8-21 ERU Output Connections in XC27x5X**

| Output | from/to Module | I/O to OGUY | Can be used to/as |
|--------|----------------|-------------|-------------------|
|--------|----------------|-------------|-------------------|

#### OGU0 Outputs

|            |                                                                                                          |   |                                |
|------------|----------------------------------------------------------------------------------------------------------|---|--------------------------------|
| ERU_PDOUT0 | ADC0 (REQGT0E)<br>ADC0 (REQGT1E)<br>ADC0 (REQGT2E)<br>ADC1 (REQGT0E)<br>ADC1 (REQGT1E)<br>ADC1 (REQGT2E) | O | Pattern detection output       |
| ERU_GOUT0  | not connected                                                                                            | O | Gated pattern detection output |
| ERU_GOUT0  | not connected                                                                                            | O | Gated pattern detection output |
| ERU_TOUT0  | not connected                                                                                            | O | Trigger output                 |
| ERU_IOUT0  | ITC (SCU_ERU_0IC)                                                                                        | O | Interrupt output               |

#### OGU1 Outputs

|            |                                                                                                          |   |                                |
|------------|----------------------------------------------------------------------------------------------------------|---|--------------------------------|
| ERU_PDOUT1 | ADC0 (REQGT0F)<br>ADC0 (REQGT1F)<br>ADC0 (REQGT2F)<br>ADC1 (REQGT0F)<br>ADC1 (REQGT1F)<br>ADC1 (REQGT2F) | O | Pattern detection output       |
| ERU_GOUT1  | not connected                                                                                            | O | Gated pattern detection output |
| ERU_TOUT1  | ADC0 (REQTR0B)<br>ADC0 (REQTR1B)<br>ADC0 (REQTR2B)<br>ADC1 (REQTR0B)<br>ADC1 (REQTR1B)<br>ADC1 (REQTR2B) | O | Trigger output                 |
| ERU_IOUT1  | ITC (SCU_ERU_1IC)                                                                                        | O | Interrupt output               |

#### OGU2 Outputs

## System Control Unit (SCU)

**Table 8-21 ERU Output Connections in XC27x5X (cont'd)**

| <b>Output</b> | <b>from/to Module</b> | <b>I/O to OGUy</b> | <b>Can be used to/as</b>       |
|---------------|-----------------------|--------------------|--------------------------------|
| ERU_PDOUT2    | CCU60 (CTRAPD)        | O                  | Pattern detection output       |
| ERU_GOUT2     | not connected         | O                  | Gated pattern detection output |
| ERU_TOUT2     | not connected         | O                  | Trigger output                 |
| ERU_IOUT2     | ITC (SCU_ERU_2IC)     | O                  | Interrupt output               |

**OGU3 Outputs**

|            |                   |   |                                |
|------------|-------------------|---|--------------------------------|
| ERU_PDOUT3 | CCU63 (CTRAPD)    | O | Pattern detection output       |
| ERU_GOUT3  | not connected     | O | Gated pattern detection output |
| ERU_TOUT3  | not connected     | O | Trigger output                 |
| ERU_IOUT3  | ITC (SCU_ERU_3IC) | O | Interrupt output               |



## 9 Parallel Ports

The XC27x5X provides a set of General Purpose Input/Output (GPIO) ports that can be controlled by software and by the on-chip peripheral units:

**Table 9-1** Ports of the XC27x5X

| Group | Width | I/O | Connected Modules                                                                                   |
|-------|-------|-----|-----------------------------------------------------------------------------------------------------|
| P0    | 8     | I/O | EBC (A7...A0), CCU6, USIC, CAN                                                                      |
| P1    | 8     | I/O | EBC (A15...A8), CCU6, USIC                                                                          |
| P2    | 14    | I/O | EBC (READY, $\overline{BHE}$ , A23...A16, AD15...AD13, D15...D13), CAN, CC2, GPT12E, USIC, DAP/JTAG |
| P3    | 8     | I/O | EBC arbitration ( $\overline{BREQ}$ , $\overline{HLDA}$ , $\overline{HOLD}$ ), CAN, USIC            |
| P4    | 8     | I/O | EBC ( $\overline{CS4}$ ... $\overline{CS0}$ ), CC2, CAN, GPT12E, USIC                               |
| P5    | 16    | I   | Analog Inputs, CCU6, DAP/JTAG, GPT12E, CAN                                                          |
| P6    | 4     | I/O | ADC, CAN, GPT12E                                                                                    |
| P7    | 5     | I/O | CAN, GPT12E, SCU, DAP/JTAG, CCU6, ADC, USIC                                                         |
| P8    | 7     | I/O | CCU6, DAP/JTAG, USIC                                                                                |
| P9    | 8     | I/O | CCU6, DAP/JTAG, CAN                                                                                 |
| P10   | 16    | I/O | EBC(ALE, $\overline{RD}$ , $\overline{WR}$ , AD12...AD0, D12...D0), CCU6, USIC, DAP/JTAG, CAN       |
| P11   | 6     | I/O | CCU6, USIC, CAN                                                                                     |
| P15   | 8     | I   | Analog Inputs, GPT12E                                                                               |

*Note: The availability of ports and port pins depends on the selected device type.  
 This chapter describes the maximum set of ports.*

## 9.1 General Description

This chapter describes the architecture of the digital control circuit for a single port pin.

### 9.1.1 Basic Port Operation

There are three types of digital control circuits: with/without hardware override for digital GPIOs, and for one for analog inputs. Each port pin contains one of them.



**Figure 9-1 Structure of the Ports without Hardware Override Functionality**

Note: INV signal is derived from Pn\_IOCR.PC[3:2].



Standard\_EBCport\_structure\_5\_um.vsd

**Figure 9-2 Structure of the Ports with Hardware Override Functionality**

*Note: If HW\_EN is activated, INV\* signal is always zero.*

*Note: When HW\_EN is disabled, the respective ports go to Power Save Mode as all other ports. When HW\_EN is active, then the user should set the POCON.PPSx=0.*



**Figure 9-3 Structure of Port 5 and Port 15**

*Note: There is always a standard digital input connected in parallel to each analog input.*

### 9.1.2 Input Stage Control

An input stage consists of a Schmitt trigger, which can be enabled or disabled via software, and an input multiplexer that by default selects the output of the input Schmitt trigger.

A disabled input driver drives high logical level. During and after reset, all input stages are enabled by default.

### 9.1.3 Output Driver Control

An output stage consists of an output driver, output multiplexer, and register bit fields for their control.

#### 9.1.3.1 Active Mode Behavior

Each output driver can be configured in a push-pull or an open-drain mode, or it can be deactivated (three-stated). An output multiplexer in front of the output driver selects the signal source, choosing either the appropriate bit of the Pn\_OUT register, or one of maximum three lines coming from a peripheral unit, see [Figure 9-1](#). The selection is done via the Pn\_IOCR register. Software can set or clear the bit Pn\_OUT.Px, which drives the port pin in case it is selected by the output multiplexer.

An output driver with hardware override can select an additional output signal coming from a peripheral. While the hardware override is activated, this signal has higher priority than all other output signals and can not be deselected by the port. In this case, the peripheral controls the direction of the pin.

#### 9.1.3.2 Power Saving Mode Behavior

In Power Saving Mode (core and IO supply voltages available), the behavior of a pin depends on the setting of the POCONx.PPSx bit. Basically, groups of four pins within a port can be configured to react to Power Save Mode Request or to ignore it. In case a pin group is configured to react to a Power Save Mode Request, each pin within a group reacts according to its own configuration according to the [Table 9-4](#).

#### 9.1.3.3 Reset Behavior

During reset, all output stages of GPIO pins go to tri-state mode without any pull-up or pull-down device.

#### 9.1.3.4 Power-fail Behavior

When the core supply fails while the pad supply remains stable, the output stages go into tri-state mode.

## 9.2 Port Register Description

### 9.2.1 Pad Driver Control

The pad structure used in this device offers the possibility to select the output driver strength and the slew rate. These selections are independent from the output port functionality, such as open-drain, push/pull or input only.

In order to minimize EMI problems, the driver strength can be adapted to the application requirements by bit fields PDMx. The selection is done in groups of four pins.

The **Port Output Control registers** POCON provide the corresponding control bits. A 4-bit control field configures the driver strength and the edge shape. Word ports consume four control nibbles each, byte ports consume two control nibbles each, where each control nibble controls 4 pins of the respective port.

*Note: P2\_POCON register in the XC27x5X contains an exception regarding the additional strong output driver connected in parallel to the standard output driver of the P2.8 pin. See the respective port section for details.*

## Parallel Ports

**Px\_PCON (x=0-4)**

 Port x Output Control Register XSFR ( $E8A0_H + 2*x$ )

 Reset Value:  $0000_H$ 
**Px\_PCON (x=6-11)**

 Port x Output Control Register XSFR ( $E8A0_H + 2*x$ )

 Reset Value:  $0000_H$ 

| 15       | 14   | 13       | 12   | 11       | 10   | 9        | 8    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|------|----------|------|----------|------|----------|------|---|---|---|---|---|---|---|---|
| PPS<br>3 | PDM3 | PPS<br>2 | PDM2 | PPS<br>1 | PDM1 | PPS<br>0 | PDM0 |   |   |   |   |   |   |   |   |

rw              rwr              rw              rw              rw              rw              rw              rw              rw

| Field                                                       | Bit                                    | Type | Description                                                                                                                                                                                                                                                                                                                                 |
|-------------------------------------------------------------|----------------------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>PDM0,</b><br><b>PDM1,</b><br><b>PDM2,</b><br><b>PDM3</b> | [2:0],<br>[6:4],<br>[10:8],<br>[14:12] | rw   | <b>Port Driver Mode x</b><br>Code Driver strength <sup>1)</sup><br>000 <sub>B</sub> Strong driver<br>001 <sub>B</sub> Strong driver<br>010 <sub>B</sub> Strong driver<br>011 <sub>B</sub> Weak driver<br>100 <sub>B</sub> Medium driver<br>101 <sub>B</sub> Medium driver<br>110 <sub>B</sub> Medium driver<br>111 <sub>B</sub> Weak driver |
| <b>PPS0,</b><br><b>PPS1,</b><br><b>PPS2,</b><br><b>PPS3</b> | 3,<br>7,<br>11,<br>15                  | rw   | <b>Pin Power Save</b><br>0 <sub>B</sub> Pin behaves like in the Active Mode. Power Save Management is ignored.<br>1 <sub>B</sub> Behavior in the Power Save Mode described in the <a href="#">Table 9-4</a> .                                                                                                                               |

<sup>1)</sup> Defines the current the respective driver can deliver to the external circuitry.

<sup>2)</sup> Defines the switching characteristics to the respective new output level. This also influences the peak currents through the driver when producing an edge, i.e. when changing the output level.

### Mapping of the POCON Registers to Pins and Ports

The table below lists the defined POCON registers and the allocation of control bit fields and port pins.

**Table 9-2 Port Output Control Register Allocation**

| Control Register | Controlled Pins (by Px_POCON.[y:z]) <sup>1)</sup> |                                      |           |           | Port Width |
|------------------|---------------------------------------------------|--------------------------------------|-----------|-----------|------------|
|                  | [15:12]                                           | [11:8]                               | [7:4]     | [3:0]     |            |
| P0_POCON         | ---                                               | ---                                  | P0.[7:4]  | P0.[3:0]  | 8          |
| P1_POCON         | ---                                               | ---                                  | P1.[7:4]  | P1.[3:0]  | 8          |
| P2_POCON         | CLOCKOUT driver at P2.8 <sup>2)</sup>             | P2.[11:8] + P2.[13:12] <sup>3)</sup> | P2.[7:4]  | P2.[3:0]  | 14         |
| P3_POCON         | ---                                               | ---                                  | P3.[7:4]  | P3.[3:0]  | 8          |
| P4_POCON         | ---                                               | ---                                  | P4.[7:4]  | P4.[3:0]  | 8          |
| P6_POCON         | ---                                               | ---                                  | ---       | P6.[3:0]  | 4          |
| P7_POCON         | ---                                               | ---                                  | P7.4      | P7.[3:0]  | 5          |
| P8_POCON         | ---                                               | ---                                  | P8.[6:4]  | P8.[3:0]  | 7          |
| P9_POCON         | ---                                               | ---                                  | P9.[7:4]  | P9.[3:0]  | 8          |
| P10_POCON        | P10.[15:12]                                       | P10.[11:8]                           | P10.[7:4] | P10.[3:0] | 16         |
| P11_POCON        | ---                                               | ---                                  | P11.[5:4] | P11.[3:0] | 6          |

<sup>1)</sup> x denotes the port number, while [y:z] represents the bit field range.

<sup>2)</sup> The control of the additional driver is described in [Chapter 9.3.3](#).

<sup>3)</sup> The output control of P2.[13:12] deviates from the standard definition, see [Chapter 9.3.3](#).

*Note: When assigning functional signals to port pins, please consider the fact that the driver strength is selected for pin groups. Assign functions with similar requirements to pins within the same POCON control group.*

## Parallel Ports

### 9.2.2 Port Output Register

The port output register defines the values of the output pins if the pin is used as GPIO output.

**Pn\_OUT (n=0-4)**
**Port n Output Register**
**SFR (FFA2<sub>H</sub>+2\*n)**
**Reset Value: 0000<sub>H</sub>**
**Pn\_OUT (n=6-11)**
**Port n Output Register**
**SFR (FFA2<sub>H</sub>+2\*n)**
**Reset Value: 0000<sub>H</sub>**

| 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| P15 | P14 | P13 | P12 | P11 | P10 | P9  | P8  | P7  | P6  | P5  | P4  | P3  | P2  | P1  | P0  |
| rwh |

| Field            | Bits | Type | Description                                                                                                                                                                                                                            |
|------------------|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Px<br>(x = 0-15) | x    | rwh  | <b>Port Output Bit x</b><br>This bit defines the level at the output pin of port Pn, pin x if the output is selected as GPIO output.<br>0 <sub>B</sub> The output level of Pn.x is 0.<br>1 <sub>B</sub> The output level of Pn.x is 1. |

## Parallel Ports

### 9.2.3 Port Output Modification Register

The port output modification register contains the bits to individually set, clear, or toggle the value of the port n output register.

#### P2\_OMRH

**Port 2 Output Modification Register HighXSFR (E9CA<sub>H</sub>)**

Reset Value: XXXX<sub>H</sub>

#### P10\_OMRH

**Port 10 Output Modification Register HighXSFR (E9EA<sub>H</sub>)**

Reset Value: XXXX<sub>H</sub>

| 15       | 14       | 13       | 12       | 11       | 10       | 9       | 8       | 7        | 6        | 5        | 4        | 3        | 2        | 1       | 0       |
|----------|----------|----------|----------|----------|----------|---------|---------|----------|----------|----------|----------|----------|----------|---------|---------|
| PC<br>15 | PC<br>14 | PC<br>13 | PC<br>12 | PC<br>11 | PC<br>10 | PC<br>9 | PC<br>8 | PS<br>15 | PS<br>14 | PS<br>13 | PS<br>12 | PS<br>11 | PS<br>10 | PS<br>9 | PS<br>8 |
| W        | W        | W        | W        | W        | W        | W       | W       | W        | W        | W        | W        | W        | W        | W       | W       |

| Field             | Bits | Type | Description                                                                                                                                                                                                      |
|-------------------|------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PSx<br>(x = 8-15) | x-8  | w    | <b>Port Set Bit x</b><br>Setting this bit sets or toggles the corresponding bit in the port output register Pn_OUT (see <a href="#">Table 9-3</a> ). On a read access, this bit returns an undefined value.      |
| PCx<br>(x = 8-15) | x    | w    | <b>Port Clear Bit x</b><br>Setting this bit clears or toggles the corresponding bit in the port output register Pn_OUT. (see <a href="#">Table 9-3</a> ). On a read access, this bit returns an undefined value. |

#### Pn\_OMRL (n=0-4)

**Port n Output Modification Register LowXSFR (E9C0<sub>H</sub>+4\*n)** Reset Value: XXXX<sub>H</sub>

#### Pn\_OMRL (n=6-11)

**Port n Output Modification Register LowXSFR (E9C0<sub>H</sub>+4\*n)** Reset Value: XXXX<sub>H</sub>

| 15      | 14      | 13      | 12      | 11      | 10      | 9       | 8       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|
| PC<br>7 | PC<br>6 | PC<br>5 | PC<br>4 | PC<br>3 | PC<br>2 | PC<br>1 | PC<br>0 | PS<br>7 | PS<br>6 | PS<br>5 | PS<br>4 | PS<br>3 | PS<br>2 | PS<br>1 | PS<br>0 |
| W       | W       | W       | W       | W       | W       | W       | W       | W       | W       | W       | W       | W       | W       | W       | W       |

| Field                          | Bits  | Type | Description                                                                                                                                                                                                      |
|--------------------------------|-------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>PSx</b><br><b>(x = 0-7)</b> | x     | w    | <b>Port Set Bit x</b><br>Setting this bit sets or toggles the corresponding bit in the port output register Pn_OUT (see <a href="#">Table 9-3</a> ). On a read access, this bit returns an undefined value.      |
| <b>PCx</b><br><b>(x = 0-7)</b> | x + 8 | w    | <b>Port Clear Bit x</b><br>Setting this bit clears or toggles the corresponding bit in the port output register Pn_OUT. (see <a href="#">Table 9-3</a> ). On a read access, this bit returns an undefined value. |

### Function of the PCx and PSx bit fields

**Table 9-3 Function of the Bits PCx and PSx**

| PCx                  | PSx                  | Function                      |
|----------------------|----------------------|-------------------------------|
| 0 or no write access | 0 or no write access | Bit Pn_OUT.Px is not changed. |
| 0 or no write access | 1                    | Bit Pn_OUT.Px is set.         |
| 1                    | 0 or no write access | Bit Pn_OUT.Px is cleared.     |
| 1                    | 1                    | Bit Pn_OUT.Px is toggled.     |

*Note: If a bit position is not written (one out of two bytes not targeted by a byte write), the corresponding value is considered as 0. Toggling a bit requires one 16-bit write.*

## Parallel Ports

### 9.2.4 Port Input Register

The port input register contains the values currently read at the input pins, also if a port line is assigned as output.

**Pn\_IN (n=0-11)**
**Port n Input Register**
**SFR (FF80<sub>H</sub>+2\*n)**
**Reset Value: 0000<sub>H</sub><sup>1)</sup>**
**P15\_IN**
**Port 15 Input Register**
**SFR (FF9E<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub><sup>1)</sup>**

| 15  | 14  | 13  | 12  | 11  | 10  | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| P15 | P14 | P13 | P12 | P11 | P10 | P9 | P8 | P7 | P6 | P5 | P4 | P3 | P2 | P1 | P0 |

<sup>1)</sup> Px bits for non implemented I/O lines are always read as 0.

| Field            | Bits | Type | Description                                                                                                                                                                                 |
|------------------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Px<br>(x = 0-15) | x    | rh   | <b>Port Input Bit x</b><br>This bit indicates the level at the input pin of port Pn, pin x.<br>0 <sub>B</sub> The input level of Pn.x is 0.<br>1 <sub>B</sub> The input level of Pn.x is 1. |

### 9.2.5 Port Input/Output Control Registers

The port input/output control registers contain the bit fields to select the digital output and input driver characteristics, such as pull-up/down devices, port direction (input/output), open-drain and alternate output selections. The coding of the options is shown in **Table 9-4**.

Depending on the port functionality not all of the input/output control registers may be implemented. The structure with one control bit field for each port pin located in different register offers the possibility to configure port pin functionality of a single pin without accessing some other PCx in the same register by word-oriented writes.

#### P0\_IOCRx (x=00-07)

**Port 0 Input/Output Control Register x XSFR ( $E800_H+2*x$ )**      **Reset Value: 0000<sub>H</sub>**

#### P1\_IOCRx (x=00-07)

**Port 1 Input/Output Control Register x XSFR ( $E820_H+2*x$ )**      **Reset Value: 0000<sub>H</sub>**

#### P2\_IOCRx (x=00-13)

**Port 2 Input/Output Control Register x XSFR ( $E840_H+2*x$ )**      **Reset Value: 0000<sub>H</sub>**

#### P3\_IOCRx (x=00-07)

**Port 3 Input/Output Control Register x XSFR ( $E860_H+2*x$ )**      **Reset Value: 0000<sub>H</sub>**

#### P4\_IOCRx (x=00-07)

**Port 4 Input/Output Control Register x XSFR ( $E880_H+2*x$ )**      **Reset Value: 0000<sub>H</sub>**

#### P6\_IOCRx (x=00-03)

**Port 6 Input/Output Control Register x XSFR ( $E8C0_H+2*x$ )**      **Reset Value: 0000<sub>H</sub>**

#### P7\_IOCRx (x=00-04)

**Port 7 Input/Output Control Register x XSFR ( $E8E0_H+2*x$ )**      **Reset Value: 0000<sub>H</sub>**

#### P8\_IOCRx (x=00-06)

**Port 8 Input/Output Control Register x XSFR ( $E900_H+2*x$ )**      **Reset Value: 0000<sub>H</sub>**

#### P9\_IOCRx (x=00-07)

**Port 9 Input/Output Control Register x XSFR ( $E920_H+2*x$ )**      **Reset Value: 0000<sub>H</sub>**

#### P10\_IOCRx (x=00-15)

**Port 10 Input/Output Control Register x XSFR ( $E940_H+2*x$ )**      **Reset Value: 0000<sub>H</sub>**

#### P11\_IOCRx (x=00-05)

**Port 11 Input/Output Control Register x XSFR ( $E960_H+2*x$ )**      **Reset Value: 0000<sub>H</sub>**



| Field | Bits             | Type | Description                                                           |
|-------|------------------|------|-----------------------------------------------------------------------|
| PC    | [7:4]            | rw   | <b>Port Input/Output Control Bit</b><br>see <a href="#">Table 9-4</a> |
| 0     | [3:0],<br>[15:8] | r    | reserved                                                              |

### Coding of the PC bit field

The coding of the GPIO port behavior is done by the bit fields in the port control registers Pn\_IOCRx. There's a control bit field PC for each port pin. The bit fields PC are located in separate control registers in order to allow modifying a port pin (without influencing the others) with simple move operations.

*Note: When the pin direction is switched to output and the mode is test mode, the output characteristic must be push-pull only.*

**Table 9-4 PC Coding**

| PC[3:0]           | I/O            | Selected Pull-up/down / Selected Output Function                                           | Behavior in Power Saving Mode <sup>1)</sup>                                                                                                   |
|-------------------|----------------|--------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 0000 <sub>B</sub> | Direct Input   | No pull device connected                                                                   | Input value = Pn_OUT; no pull                                                                                                                 |
| 0001 <sub>B</sub> |                | Pull-down device connected                                                                 | Input value = 0; pull-down                                                                                                                    |
| 0010 <sub>B</sub> |                | Pull-up device connected                                                                   | Input value = 1; pull-up                                                                                                                      |
| 0011 <sub>B</sub> |                | No pull device connected.<br>In this mode Pn_OUT samples the pad input value continuously. | Input value = Pn_OUT; Pn_OUT always samples input value while not in power save mode = freeze of input value; no pull                         |
| 0100 <sub>B</sub> | Inverted Input | No pull device connected                                                                   | Input value = <u>Pn_OUT</u> ; no pull                                                                                                         |
| 0101 <sub>B</sub> |                | Pull-down device connected                                                                 | Input value = 1; pull-down                                                                                                                    |
| 0110 <sub>B</sub> |                | Pull-up device connected                                                                   | Input value = 0; pull-up                                                                                                                      |
| 0111 <sub>B</sub> |                | No pull device connected<br>In this mode Pn_OUT samples the pad input value continuously.  | Input value = <u>Pn_OUT</u> ; Pn_OUT always samples input value while not in power saving mode = freeze of input value; no pull <sup>2)</sup> |

## Parallel Ports

**Table 9-4 PC Coding**

| <b>PC[3:0]</b> | <b>I/O</b>                             | <b>Selected Pull-up/down / Selected Output Function</b> | <b>Behavior in Power Saving Mode<sup>1)</sup></b>                                                   |
|----------------|----------------------------------------|---------------------------------------------------------|-----------------------------------------------------------------------------------------------------|
| $1000_B$       | Output<br>(Direct input)<br>Push-pull  | General purpose Output                                  | Output driver off.<br>Input Schmitt trigger off.<br>Pn_OUT delivered to the internal logic; no pull |
| $1001_B$       |                                        | Output function ALT1                                    |                                                                                                     |
| $1010_B$       |                                        | Output function ALT2                                    |                                                                                                     |
| $1011_B$       |                                        | Output function ALT3                                    |                                                                                                     |
| $1100_B$       | Output<br>(Direct input)<br>Open-drain | General purpose Output                                  |                                                                                                     |
| $1101_B$       |                                        | Output function ALT1                                    |                                                                                                     |
| $1110_B$       |                                        | Output function ALT2                                    |                                                                                                     |
| $1111_B$       |                                        | Output function ALT3                                    |                                                                                                     |

<sup>1)</sup> In power saving mode, the input Schmitt trigger is always switched off. A defined input value is driven to the internal circuitry instead of the level detected at the input pin.

<sup>2)</sup> If the IOCR setting is “inverted input”, then an inverted signal Pn\_OUT is driven internally. The Pn\_OUT register itself always contains the real, non-inverted input value of the pin. See Figure 7-1 and Figure 7-2.

## Parallel Ports

### 9.2.6 Port Digital Input Disable Register

Ports 5 and 15 have, additionally to the analog input functionality, digital input functionality too. In order to save switching of the internal Schmitt triggers of the digital inputs, they can be disabled by means of Px\_DIDIS Register.

#### P5\_DIDIS

**Port 5 Digital Input Disable RegisterSFR (FE8A<sub>H</sub>)**

**Reset Value: 0000<sub>H</sub>**

#### P15\_DIDIS

**Port 15 Digital Input Disable RegisterSFR (FE9E<sub>H</sub>)**

**Reset Value: 0000<sub>H</sub>**

| 15  | 14  | 13  | 12  | 11  | 10  | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| P15 | P14 | P13 | P12 | P11 | P10 | P9 | P8 | P7 | P6 | P5 | P4 | P3 | P2 | P1 | P0 |

rw      rw

| Field            | Bit | Type | Description                                                                                                                                                                                                    |
|------------------|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Py<br>(y = 0-15) | y   | rw   | Bit y Digital Input Control<br>0 <sub>B</sub> Digital input stage (schmitt trigger) is enabled.<br>1 <sub>B</sub> Digital input stage (schmitt trigger) is disabled, necessary if pin is used as analog input. |

## 9.3 Port Description

The bit positions in the port registers always start right-aligned. For example, a port comprising only 8 pins only uses the bit positions [7:0] of the corresponding register. The remaining bit positions are filled with 0 (r).

The pad driver mode registers may be different for each port. As a result, they are described independently for each port in the corresponding chapter.

### 9.3.1 Port 0

Port 0 is an 8-bit GPIO port. The registers of Port 0 are shown in [Figure 9-4](#).

For this port, all pins can be read as GPIO, from the Port Input Register.



**Figure 9-4 Port 0 Register Overview**

**Table 9-5 Port 0 Registers**

| Register Short Name | Register Long Name                      | Address Offset    | Reset Value       |
|---------------------|-----------------------------------------|-------------------|-------------------|
| P0_OUT              | Port 0 Output Register                  | FFA2 <sub>H</sub> | 0000 <sub>H</sub> |
| P0_IN               | Port 0 Input Register                   | FF80 <sub>H</sub> | 0000 <sub>H</sub> |
| P0_OMRL             | Port 0 Output Modification Register Low | E9C0 <sub>H</sub> | XXXX <sub>H</sub> |
| P0_POCN             | Port 0 Output Control Register          | E8A0 <sub>H</sub> | 0000 <sub>H</sub> |
| P0_IOCR00           | Port 0 Input/Output Control Register 0  | E800 <sub>H</sub> | 0000 <sub>H</sub> |
| P0_IOCR01           | Port 0 Input/Output Control Register 1  | E802 <sub>H</sub> | 0000 <sub>H</sub> |
| P0_IOCR02           | Port 0 Input/Output Control Register 2  | E804 <sub>H</sub> | 0000 <sub>H</sub> |
| P0_IOCR03           | Port 0 Input/Output Control Register 3  | E806 <sub>H</sub> | 0000 <sub>H</sub> |
| P0_IOCR04           | Port 0 Input/Output Control Register 4  | E808 <sub>H</sub> | 0000 <sub>H</sub> |
| P0_IOCR05           | Port 0 Input/Output Control Register 5  | E80A <sub>H</sub> | 0000 <sub>H</sub> |
| P0_IOCR06           | Port 0 Input/Output Control Register 6  | E80C <sub>H</sub> | 0000 <sub>H</sub> |
| P0_IOCR07           | Port 0 Input/Output Control Register 7  | E80E <sub>H</sub> | 0000 <sub>H</sub> |

### 9.3.2 Port 1

Port 1 is an 8-bit GPIO port. The registers of Port 1 are shown in [Figure 9-5](#).



**Figure 9-5 Port 1 Register Overview**

For this port, all pins can be read as GPIO, from the Port Input Register.

**Table 9-6 Port 1 Registers**

| Register Short Name | Register Long Name                      | Address Offset    | Reset Value       |
|---------------------|-----------------------------------------|-------------------|-------------------|
| P1_OUT              | Port 1 Output Register                  | FFA4 <sub>H</sub> | 0000 <sub>H</sub> |
| P1_IN               | Port 1 Input Register                   | FF82 <sub>H</sub> | 0000 <sub>H</sub> |
| P1_OMRL             | Port 1 Output Modification Register Low | E9C4 <sub>H</sub> | XXXX <sub>H</sub> |
| P1_PCON             | Port 1 Output Control Register          | E8A2 <sub>H</sub> | 0000 <sub>H</sub> |
| P1_IOCR00           | Port 1 Input/Output Control Register 0  | E820 <sub>H</sub> | 0000 <sub>H</sub> |
| P1_IOCR01           | Port 1 Input/Output Control Register 1  | E822 <sub>H</sub> | 0000 <sub>H</sub> |
| P1_IOCR02           | Port 1 Input/Output Control Register 2  | E824 <sub>H</sub> | 0000 <sub>H</sub> |
| P1_IOCR03           | Port 1 Input/Output Control Register 3  | E826 <sub>H</sub> | 0000 <sub>H</sub> |
| P1_IOCR04           | Port 1 Input/Output Control Register 4  | E828 <sub>H</sub> | 0000 <sub>H</sub> |
| P1_IOCR05           | Port 1 Input/Output Control Register 5  | E82A <sub>H</sub> | 0000 <sub>H</sub> |
| P1_IOCR06           | Port 1 Input/Output Control Register 6  | E82C <sub>H</sub> | 0000 <sub>H</sub> |
| P1_IOCR07           | Port 1 Input/Output Control Register 7  | E82E <sub>H</sub> | 0000 <sub>H</sub> |

### 9.3.3 Port 2

Port 2 is an 14-bit GPIO port. The registers of Port 2 are shown in [Figure 9-6](#).

For this port, all pins can be read as GPIO, from the Port Input Register.



**Figure 9-6 Port 2 Register Overview**

**Table 9-7 Port 2 Registers**

| Register Short Name | Register Long Name                       | Address Offset    | Reset Value       |
|---------------------|------------------------------------------|-------------------|-------------------|
| P2_OUT              | Port 2 Output Register                   | FFA6 <sub>H</sub> | 0000 <sub>H</sub> |
| P2_IN               | Port 2 Input Register                    | FF84 <sub>H</sub> | 0000 <sub>H</sub> |
| P2_OMRL             | Port 2 Output Modification Register Low  | E9C8 <sub>H</sub> | XXXX <sub>H</sub> |
| P2_OMRH             | Port 2 Output Modification Register High | E9CA <sub>H</sub> | XXXX <sub>H</sub> |
| P2_PCON             | Port 2 Output Control Register           | E8A4 <sub>H</sub> | 0000 <sub>H</sub> |
| P2_IOCR00           | Port 2 Input/Output Control Register 0   | E840 <sub>H</sub> | 0000 <sub>H</sub> |
| P2_IOCR01           | Port 2 Input/Output Control Register 1   | E842 <sub>H</sub> | 0000 <sub>H</sub> |
| P2_IOCR02           | Port 2 Input/Output Control Register 2   | E844 <sub>H</sub> | 0000 <sub>H</sub> |
| P2_IOCR03           | Port 2 Input/Output Control Register 3   | E846 <sub>H</sub> | 0000 <sub>H</sub> |
| P2_IOCR04           | Port 2 Input/Output Control Register 4   | E848 <sub>H</sub> | 0000 <sub>H</sub> |
| P2_IOCR05           | Port 2 Input/Output Control Register 5   | E84A <sub>H</sub> | 0000 <sub>H</sub> |
| P2_IOCR06           | Port 2 Input/Output Control Register 6   | E84C <sub>H</sub> | 0000 <sub>H</sub> |
| P2_IOCR07           | Port 2 Input/Output Control Register 7   | E84E <sub>H</sub> | 0000 <sub>H</sub> |
| P2_IOCR08           | Port 2 Input/Output Control Register 8   | E850 <sub>H</sub> | 0000 <sub>H</sub> |
| P2_IOCR09           | Port 2 Input/Output Control Register 9   | E852 <sub>H</sub> | 0000 <sub>H</sub> |

**Table 9-7 Port 2 Registers (cont'd)**

| <b>Register Short Name</b> | <b>Register Long Name</b>               | <b>Address Offset</b> | <b>Reset Value</b> |
|----------------------------|-----------------------------------------|-----------------------|--------------------|
| P2_IOCR10                  | Port 2 Input/Output Control Register 10 | E854 <sub>H</sub>     | 0000 <sub>H</sub>  |
| P2_IOCR11                  | Port 2 Input/Output Control Register 11 | E856 <sub>H</sub>     | 0000 <sub>H</sub>  |
| P2_IOCR12                  | Port 2 Input/Output Control Register 12 | E858 <sub>H</sub>     | 0000 <sub>H</sub>  |
| P2_IOCR13                  | Port 2 Input/Output Control Register 13 | E85A <sub>H</sub>     | 0000 <sub>H</sub>  |

### The CLKOUT Pad P2.8

In order to drive high frequency clock signals, a strong driver is connected in parallel to the normal output driver of P2.8. It is enabled instead of the standard driver while bitfield P2\_POCON.PDM3 = xx1<sub>B</sub>.

The strong clock driver only operates in strong driver sharp edge mode, i.e. it is not controlled by the driver-strength settings (P2\_POCON.PDM2) for the standard driver.

It has no pull devices but can be switched to input or output via register P2\_IOCR08.

### Output Control for Pins P2.[13:12]

Because bitfield P2\_POCON.PDM3 controls the strong clock driver of P2.8, the driver mode of pins P2.[13:12] is controlled by the bitfield P2\_POCON.PDM2, together with pins P2.[11:8].

The power saving behaviour of pins P2.[13:12] is controlled by bit P2\_POCON.PPS3.

### 9.3.4 Port 3

Port 3 is an 8-bit GPIO port. The registers of Port 3 are shown in [Figure 9-7](#).

For this port, all pins can be read as GPIO, from the Port Input Register.



**Figure 9-7 Port 3 Register Overview**

**Table 9-8 Port 3 Registers**

| Register Short Name | Register Long Name                      | Address Offset    | Reset Value       |
|---------------------|-----------------------------------------|-------------------|-------------------|
| P3_OUT              | Port 3 Output Register                  | FFA8 <sub>H</sub> | 0000 <sub>H</sub> |
| P3_IN               | Port 3 Input Register                   | FF86 <sub>H</sub> | 0000 <sub>H</sub> |
| P3_OMRL             | Port 3 Output Modification Register Low | E9CC <sub>H</sub> | XXXX <sub>H</sub> |
| P3_PCON             | Port 3 Output Control Register          | E8A6 <sub>H</sub> | 0000 <sub>H</sub> |
| P3_IOCR00           | Port 3 Input/Output Control Register 0  | E860 <sub>H</sub> | 0000 <sub>H</sub> |
| P3_IOCR01           | Port 3 Input/Output Control Register 1  | E862 <sub>H</sub> | 0000 <sub>H</sub> |
| P3_IOCR02           | Port 3 Input/Output Control Register 2  | E864 <sub>H</sub> | 0000 <sub>H</sub> |
| P3_IOCR03           | Port 3 Input/Output Control Register 3  | E866 <sub>H</sub> | 0000 <sub>H</sub> |
| P3_IOCR04           | Port 3 Input/Output Control Register 4  | E868 <sub>H</sub> | 0000 <sub>H</sub> |
| P3_IOCR05           | Port 3 Input/Output Control Register 5  | E86A <sub>H</sub> | 0000 <sub>H</sub> |
| P3_IOCR06           | Port 3 Input/Output Control Register 6  | E86C <sub>H</sub> | 0000 <sub>H</sub> |
| P3_IOCR07           | Port 3 Input/Output Control Register 7  | E86E <sub>H</sub> | 0000 <sub>H</sub> |

### 9.3.5 Port 4

Port 4 is an 8-bit GPIO port. The registers of Port 4 are shown in [Figure 9-8](#).

For this port, all pins can be read as GPIO, from the Port Input Register.



**Figure 9-8 Port 4 Register Overview**

**Table 9-9 Port 4 Registers**

| Register Short Name | Register Long Name                      | Address Offset    | Reset Value       |
|---------------------|-----------------------------------------|-------------------|-------------------|
| P4_OUT              | Port 4 Output Register                  | FFAA <sub>H</sub> | 0000 <sub>H</sub> |
| P4_IN               | Port 4 Input Register                   | FF88 <sub>H</sub> | 0000 <sub>H</sub> |
| P4_OMRL             | Port 4 Output Modification Register Low | E9D0 <sub>H</sub> | XXXX <sub>H</sub> |
| P4_PCON             | Port 4 Output Control Register          | E8A8 <sub>H</sub> | 0000 <sub>H</sub> |
| P4_IOCR00           | Port 4 Input/Output Control Register 0  | E880 <sub>H</sub> | 0000 <sub>H</sub> |
| P4_IOCR01           | Port 4 Input/Output Control Register 1  | E882 <sub>H</sub> | 0000 <sub>H</sub> |
| P4_IOCR02           | Port 4 Input/Output Control Register 2  | E884 <sub>H</sub> | 0000 <sub>H</sub> |
| P4_IOCR03           | Port 4 Input/Output Control Register 3  | E886 <sub>H</sub> | 0000 <sub>H</sub> |
| P4_IOCR04           | Port 4 Input/Output Control Register 4  | E888 <sub>H</sub> | 0000 <sub>H</sub> |
| P4_IOCR05           | Port 4 Input/Output Control Register 5  | E88A <sub>H</sub> | 0000 <sub>H</sub> |
| P4_IOCR06           | Port 4 Input/Output Control Register 6  | E88C <sub>H</sub> | 0000 <sub>H</sub> |
| P4_IOCR07           | Port 4 Input/Output Control Register 7  | E88E <sub>H</sub> | 0000 <sub>H</sub> |

### 9.3.6 Port 5

Port 5 is a 16-bit analog or digital input port.

To use the Port 5 as an analog input, the Schmitt trigger in the input stage must be disabled. This is achieved by setting the corresponding bit in the register P5\_DIDIS.



Figure 9-9 Port 5 Register Overview

Table 9-10 Port 5 Registers

| Register Short Name | Register Long Name                    | Address Offset | Reset Value |
|---------------------|---------------------------------------|----------------|-------------|
| P5_IN               | Port 5 Input Register                 | FF8AH          | 0000H       |
| P5_DIDIS            | Port 5 Digital Input Disable Register | FE8AH          | 0000H       |

### 9.3.7 Port 6

Port 6 is a 4-bit GPIO port. The registers of Port 6 are shown in [Figure 9-10](#).

For this port, all pins can be read as GPIO, from the Port Input Register.



**Figure 9-10 Port 6 Register Overview**

**Table 9-11 Port 6 Registers**

| Register Short Name | Register Long Name                      | Address Offset    | Reset Value       |
|---------------------|-----------------------------------------|-------------------|-------------------|
| P6_OUT              | Port 6 Output Register                  | FFAE <sub>H</sub> | 0000 <sub>H</sub> |
| P6_IN               | Port 6 Input Register                   | FF8C <sub>H</sub> | 0000 <sub>H</sub> |
| P6_OMRL             | Port 6 Output Modification Register Low | E9D8 <sub>H</sub> | XXXX <sub>H</sub> |
| P6_PCON             | Port 6 Output Control Register          | E8AC <sub>H</sub> | 0000 <sub>H</sub> |
| P6_IOCR00           | Port 6 Input/Output Control Register 0  | E8C0 <sub>H</sub> | 0000 <sub>H</sub> |
| P6_IOCR01           | Port 6 Input/Output Control Register 1  | E8C2 <sub>H</sub> | 0000 <sub>H</sub> |
| P6_IOCR02           | Port 6 Input/Output Control Register 2  | E8C4 <sub>H</sub> | 0000 <sub>H</sub> |
| P6_IOCR03           | Port 6 Input/Output Control Register 3  | E8C6 <sub>H</sub> | 0000 <sub>H</sub> |

### 9.3.8 Port 7

Port 7 is a 5-bit GPIO port. The port registers of Port 7 are shown in [Figure 9-11](#).

For this port, all pins can be read as GPIO, from the Port Input Register.



**Figure 9-11 Port 7 Register Overview**

**Table 9-12 Port 7 Registers**

| Register Short Name | Register Long Name                      | Address Offset    | Reset Value       |
|---------------------|-----------------------------------------|-------------------|-------------------|
| P7_OUT              | Port 7 Output Register                  | FFB0 <sub>H</sub> | 0000 <sub>H</sub> |
| P7_IN               | Port 7 Input Register                   | FF8E <sub>H</sub> | 0000 <sub>H</sub> |
| P7_OMRL             | Port 7 Output Modification Register Low | E9DC <sub>H</sub> | XXXX <sub>H</sub> |
| P7_PCON             | Port 7 Output Control Register          | E8AE <sub>H</sub> | 0000 <sub>H</sub> |
| P7_IOCR00           | Port 7 Input/Output Control Register 0  | E8E0 <sub>H</sub> | 0000 <sub>H</sub> |
| P7_IOCR01           | Port 7 Input/Output Control Register 1  | E8E2 <sub>H</sub> | 0000 <sub>H</sub> |
| P7_IOCR02           | Port 7 Input/Output Control Register 2  | E8E4 <sub>H</sub> | 0000 <sub>H</sub> |
| P7_IOCR03           | Port 7 Input/Output Control Register 3  | E8E6 <sub>H</sub> | 0000 <sub>H</sub> |
| P7_IOCR04           | Port 7 Input/Output Control Register 4  | E8E8 <sub>H</sub> | 0000 <sub>H</sub> |

### 9.3.9 Port 8

Port 8 is an 8-bit GPIO port. The registers of Port 8 are shown in [Figure 9-12](#).

For this port, all pins can be read as GPIO, from the Port Input Register.



**Figure 9-12 Port 8 Register Overview**

**Table 9-13 Port 8 Registers**

| Register Short Name | Register Long Name                      | Address Offset    | Reset Value       |
|---------------------|-----------------------------------------|-------------------|-------------------|
| P8_OUT              | Port 8 Output Register                  | FFB2 <sub>H</sub> | 0000 <sub>H</sub> |
| P8_IN               | Port 8 Input Register                   | FF90 <sub>H</sub> | 0000 <sub>H</sub> |
| P8_OMRL             | Port 8 Output Modification Register Low | E9E0 <sub>H</sub> | XXXX <sub>H</sub> |
| P8_PCON             | Port 8 Output Control Register          | E8B0 <sub>H</sub> | 0000 <sub>H</sub> |
| P8_IOCR00           | Port 8 Input/Output Control Register 0  | E900 <sub>H</sub> | 0000 <sub>H</sub> |
| P8_IOCR01           | Port 8 Input/Output Control Register 1  | E902 <sub>H</sub> | 0000 <sub>H</sub> |
| P8_IOCR02           | Port 8 Input/Output Control Register 2  | E904 <sub>H</sub> | 0000 <sub>H</sub> |
| P8_IOCR03           | Port 8 Input/Output Control Register 3  | E906 <sub>H</sub> | 0000 <sub>H</sub> |
| P8_IOCR04           | Port 8 Input/Output Control Register 4  | E908 <sub>H</sub> | 0000 <sub>H</sub> |
| P8_IOCR05           | Port 8 Input/Output Control Register 5  | E90A <sub>H</sub> | 0000 <sub>H</sub> |
| P8_IOCR06           | Port 8 Input/Output Control Register 6  | E90C <sub>H</sub> | 0000 <sub>H</sub> |

### 9.3.10 Port 9

Port 9 is an 8-bit GPIO port. The port registers of Port 9 are shown in [Figure 9-13](#).

For this port, all pins can be read as GPIO, from the Port Input Register.



**Figure 9-13 Port 9 Register Overview**

**Table 9-14 Port 9 Registers**

| Register Short Name | Register Long Name                      | Address Offset    | Reset Value       |
|---------------------|-----------------------------------------|-------------------|-------------------|
| P9_OUT              | Port 9 Output Register                  | FFB4 <sub>H</sub> | 0000 <sub>H</sub> |
| P9_IN               | Port 9 Input Register                   | FF92 <sub>H</sub> | 0000 <sub>H</sub> |
| P9_OMRL             | Port 9 Output Modification Register Low | E9E4 <sub>H</sub> | XXXX <sub>H</sub> |
| P9_POCON            | Port 9 Output Control Register          | E8B2 <sub>H</sub> | 0000 <sub>H</sub> |
| P9_IOCR00           | Port 9 Input/Output Control Register 0  | E920 <sub>H</sub> | 0000 <sub>H</sub> |
| P9_IOCR01           | Port 9 Input/Output Control Register 1  | E922 <sub>H</sub> | 0000 <sub>H</sub> |
| P9_IOCR02           | Port 9 Input/Output Control Register 2  | E924 <sub>H</sub> | 0000 <sub>H</sub> |
| P9_IOCR03           | Port 9 Input/Output Control Register 3  | E926 <sub>H</sub> | 0000 <sub>H</sub> |
| P9_IOCR04           | Port 9 Input/Output Control Register 4  | E928 <sub>H</sub> | 0000 <sub>H</sub> |
| P9_IOCR05           | Port 9 Input/Output Control Register 5  | E92A <sub>H</sub> | 0000 <sub>H</sub> |
| P9_IOCR06           | Port 9 Input/Output Control Register 6  | E92C <sub>H</sub> | 0000 <sub>H</sub> |
| P9_IOCR07           | Port 9 Input/Output Control Register 7  | E92E <sub>H</sub> | 0000 <sub>H</sub> |

### 9.3.11 Port 10

Port 10 is a 16-bit GPIO port. The registers of Port 10 are shown in [Figure 9-14](#).

For this port, all pins can be read as GPIO, from the Port Input Register.



**Figure 9-14 Port 10 Register Overview**

**Table 9-15 Port 10 Registers**

| Register Short Name | Register Long Name                        | Address Offset    | Reset Value       |
|---------------------|-------------------------------------------|-------------------|-------------------|
| P10_OUT             | Port 10 Output Register                   | FFB6 <sub>H</sub> | 0000 <sub>H</sub> |
| P10_IN              | Port 10 Input Register                    | FF94 <sub>H</sub> | 0000 <sub>H</sub> |
| P10_OMRL            | Port 10 Output Modification Register Low  | E9E8 <sub>H</sub> | XXXX <sub>H</sub> |
| P10_OMRH            | Port 10 Output Modification Register High | E9EA <sub>H</sub> | XXXX <sub>H</sub> |
| P10_PCON            | Port 10 Output Control Register           | E8B4 <sub>H</sub> | 0000 <sub>H</sub> |
| P10_IOCR00          | Port 10 Input/Output Control Register 0   | E940 <sub>H</sub> | 0000 <sub>H</sub> |
| P10_IOCR01          | Port 10 Input/Output Control Register 1   | E942 <sub>H</sub> | 0000 <sub>H</sub> |
| P10_IOCR02          | Port 10 Input/Output Control Register 2   | E944 <sub>H</sub> | 0000 <sub>H</sub> |
| P10_IOCR03          | Port 10 Input/Output Control Register 3   | E946 <sub>H</sub> | 0000 <sub>H</sub> |
| P10_IOCR04          | Port 10 Input/Output Control Register 4   | E948 <sub>H</sub> | 0000 <sub>H</sub> |
| P10_IOCR05          | Port 10 Input/Output Control Register 5   | E94A <sub>H</sub> | 0000 <sub>H</sub> |
| P10_IOCR06          | Port 10 Input/Output Control Register 6   | E94C <sub>H</sub> | 0000 <sub>H</sub> |
| P10_IOCR07          | Port 10 Input/Output Control Register 7   | E94E <sub>H</sub> | 0000 <sub>H</sub> |
| P10_IOCR08          | Port 10 Input/Output Control Register 8   | E950 <sub>H</sub> | 0000 <sub>H</sub> |
| P10_IOCR09          | Port 10 Input/Output Control Register 9   | E952 <sub>H</sub> | 0000 <sub>H</sub> |

## Parallel Ports

Table 9-15 Port 10 Registers (cont'd)

| Register Short Name | Register Long Name                       | Address Offset    | Reset Value       |
|---------------------|------------------------------------------|-------------------|-------------------|
| P10_IOCR10          | Port 10 Input/Output Control Register 10 | E954 <sub>H</sub> | 0000 <sub>H</sub> |
| P10_IOCR11          | Port 10 Input/Output Control Register 11 | E956 <sub>H</sub> | 0000 <sub>H</sub> |
| P10_IOCR12          | Port 10 Input/Output Control Register 12 | E958 <sub>H</sub> | 0000 <sub>H</sub> |
| P10_IOCR13          | Port 10 Input/Output Control Register 13 | E95A <sub>H</sub> | 0000 <sub>H</sub> |
| P10_IOCR14          | Port 10 Input/Output Control Register 14 | E95C <sub>H</sub> | 0000 <sub>H</sub> |
| P10_IOCR15          | Port 10 Input/Output Control Register 15 | E95E <sub>H</sub> | 0000 <sub>H</sub> |

### 9.3.12 Port 11

Port 11 is a 6-bit GPIO port. The registers of Port 11 are shown in [Figure 9-15](#).

For this port, all pins can be read as GPIO, from the Port Input Register.



**Figure 9-15 Port 11 Register Overview**

**Table 9-16 Port 11 Registers**

| Register Short Name | Register Long Name                       | Address Offset    | Reset Value       |
|---------------------|------------------------------------------|-------------------|-------------------|
| P11_OUT             | Port 11 Output Register                  | FFB8 <sub>H</sub> | 0000 <sub>H</sub> |
| P11_IN              | Port 11 Input Register                   | FF96 <sub>H</sub> | 0000 <sub>H</sub> |
| P11_OMRL            | Port 11 Output Modification Register Low | E9EC <sub>H</sub> | XXXX <sub>H</sub> |
| P11_POCN            | Port 11 Output Control Register          | E8B6 <sub>H</sub> | 0000 <sub>H</sub> |
| P11_IOCR00          | Port 11 Input/Output Control Register 0  | E960 <sub>H</sub> | 0000 <sub>H</sub> |
| P11_IOCR01          | Port 11 Input/Output Control Register 1  | E962 <sub>H</sub> | 0000 <sub>H</sub> |
| P11_IOCR02          | Port 11 Input/Output Control Register 2  | E964 <sub>H</sub> | 0000 <sub>H</sub> |
| P11_IOCR03          | Port 11 Input/Output Control Register 3  | E966 <sub>H</sub> | 0000 <sub>H</sub> |
| P11_IOCR04          | Port 11 Input/Output Control Register 4  | E968 <sub>H</sub> | 0000 <sub>H</sub> |
| P11_IOCR05          | Port 11 Input/Output Control Register 5  | E96A <sub>H</sub> | 0000 <sub>H</sub> |

### 9.3.13 Port 15

Port 15 is an 8-bit analog or digital input port.

To use the Port 15 as an analog input, the Schmitt trigger in the input stage must be disabled. This is achieved by setting the corresponding bit in the register P15\_DIDIS.



**Figure 9-16 Port 15 Register Overview**

**Table 9-17 Port 15 Registers**

| Register Short Name | Register Long Name                     | Address Offset | Reset Value |
|---------------------|----------------------------------------|----------------|-------------|
| P15_IN              | Port 15 Input Register                 | FF9EH          | 0000H       |
| P15_DIDIS           | Port 15 Digital Input Disable Register | FE9EH          | 0000H       |

## 9.4 Pin Description

Each port pin of the XC27x5X can serve several functions of different modules. Also, most functions are available on several port pins. This enables an application to select the optimal connections for its specific circumstances.

A pin can output its own port output signal or one of up to three signals coming from the peripherals. Its input signal is available in its own input register and at several peripherals.

*Note: Output signals are selected at the respective port pin, input signals are selected at the respective peripheral.*

Optionally a pin can be fully controlled by a peripheral, in case the peripheral is enabled (for example, EBC).

**Table 9-18** summarizes the various functions of each port and pin of the XC27x5X. The 'Pin' column references to the PG-LQFP-144 package.

### Notes to Pin Definitions

1. **Ctrl.:** The output signal for a port pin is selected via bitfield PC in the associated register Px\_ICRy. Output O0 is selected by setting the respective bitfield PC to  $1x00_B$ , output O1 is selected by  $1x01_B$ , etc.  
*Output signal OH is controlled by hardware.*
2. **Type:** Indicates the employed pad type (St=standard pad, Sp=special pad, DP=double pad, In=input pad, PS=power supply) and its power supply domain (A, B, M, 1).

**Table 9-18 Pin Definitions and Functions**

| Pin | Symbol            | Ctrl.  | Type | Function                                                                                                                                                                                                |
|-----|-------------------|--------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3   | TESTM             | I      | In/B | <b>Testmode Enable</b><br>Enables factory test modes, must be held HIGH for normal operation (connect to $V_{DDPB}$ ).<br>An internal pullup device will hold this pin high when nothing is driving it. |
| 4   | P7.2              | O0 / I | St/B | <b>Bit 2 of Port 7, General Purpose Input/Output</b>                                                                                                                                                    |
|     | EMUX0             | O1     | St/B | <b>External Analog MUX Control Output 0 (ADC1)</b>                                                                                                                                                      |
|     | CCU62_CCP<br>OS0A | I      | St/B | <b>CCU62 Position Input 0</b>                                                                                                                                                                           |
|     | TDI_C             | I      | St/B | <b>JTAG Test Data Input</b>                                                                                                                                                                             |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol         | Ctrl.  | Type | Function                                                                                                                                                                                                                                                                                                                                                          |
|-----|----------------|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5   | P8.4           | O0 / I | St/B | <b>Bit 4 of Port 8, General Purpose Input/Output</b>                                                                                                                                                                                                                                                                                                              |
|     | CCU60_COU_T61  | O1     | St/B | <b>CCU60 Channel 1 Output</b>                                                                                                                                                                                                                                                                                                                                     |
|     | CCU62_CC6_1    | O2     | St/B | <b>CCU62 Channel 1 Output</b>                                                                                                                                                                                                                                                                                                                                     |
|     | TMS_D          | I      | St/B | <b>JTAG Test Mode Selection Input</b>                                                                                                                                                                                                                                                                                                                             |
|     | CCU62_CC6_1INB | I      | St/B | <b>CCU62 Channel 1 Input</b>                                                                                                                                                                                                                                                                                                                                      |
| 6   | TRST           | I      | In/B | <p><b>Test-System Reset Input</b></p> <p>For normal system operation, pin TRST should be held low. A high level at this pin at the rising edge of PORST activates the XC27x5X's debug system. In this case, pin TRST must be driven low once to reset the debug system.</p> <p>An internal pulldown device will hold this pin low when nothing is driving it.</p> |
| 7   | P8.3           | O0 / I | St/B | <b>Bit 3 of Port 8, General Purpose Input/Output</b>                                                                                                                                                                                                                                                                                                              |
|     | CCU60_COU_T60  | O1     | St/B | <b>CCU60 Channel 0 Output</b>                                                                                                                                                                                                                                                                                                                                     |
|     | CCU62_CC6_0    | O2     | St/B | <b>CCU62 Channel 0 Output</b>                                                                                                                                                                                                                                                                                                                                     |
|     | TDI_D          | I      | St/B | <b>JTAG Test Data Input</b>                                                                                                                                                                                                                                                                                                                                       |
|     | CCU62_CC6_0INB | I      | St/B | <b>CCU62 Channel 0 Input</b>                                                                                                                                                                                                                                                                                                                                      |
| 8   | P7.0           | O0 / I | St/B | <b>Bit 0 of Port 7, General Purpose Input/Output</b>                                                                                                                                                                                                                                                                                                              |
|     | T3OUT          | O1     | St/B | <b>GPT12E Timer T3 Toggle Latch Output</b>                                                                                                                                                                                                                                                                                                                        |
|     | T6OUT          | O2     | St/B | <b>GPT12E Timer T6 Toggle Latch Output</b>                                                                                                                                                                                                                                                                                                                        |
|     | TDO_A          | OH     | St/B | <b>DAP1/JTAG Test Data Output</b>                                                                                                                                                                                                                                                                                                                                 |
|     | ESR2_1         | I      | St/B | <b>ESR2 Trigger Input 1</b>                                                                                                                                                                                                                                                                                                                                       |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol            | Ctrl.  | Type | Function                                             |
|-----|-------------------|--------|------|------------------------------------------------------|
| 9   | P7.3              | O0 / I | St/B | <b>Bit 3 of Port 7, General Purpose Input/Output</b> |
|     | EMUX1             | O1     | St/B | <b>External Analog MUX Control Output 1 (ADC1)</b>   |
|     | U0C1_DOUT         | O2     | St/B | <b>USIC0 Channel 1 Shift Data Output</b>             |
|     | U0C0_DOUT         | O3     | St/B | <b>USIC0 Channel 0 Shift Data Output</b>             |
|     | CCU62_CCP<br>OS1A | I      | St/B | <b>CCU62 Position Input 1</b>                        |
|     | TMS_C             | I      | St/B | <b>JTAG Test Mode Selection Input</b>                |
|     | U0C1_DX0F         | I      | St/B | <b>USIC0 Channel 1 Shift Data Input</b>              |
| 10  | P8.2              | O0 / I | St/B | <b>Bit 2 of Port 8, General Purpose Input/Output</b> |
|     | CCU60_CC6<br>2    | O1     | St/B | <b>CCU60 Channel 2 Output</b>                        |
|     | TxDI1             | O2     | St/B | <b>CAN Node 1 Transmit Data Output</b>               |
|     | U1C1_DOUT         | O3     | St/B | <b>USIC1 Channel 1 Shift Data output</b>             |
|     | CCU60_CC6<br>2INB | I      | St/B | <b>CCU60 Channel 2 Input</b>                         |
| 11  | P7.1              | O0 / I | St/B | <b>Bit 1 of Port 7, General Purpose Input/Output</b> |
|     | EXTCLK            | O1     | St/B | <b>Programmable Clock Signal Output</b>              |
|     | CCU62_CTR<br>APA  | I      | St/B | <b>CCU62 Emergency Trap Input</b>                    |
|     | BRKIN_C           | I      | St/B | <b>OCDS Break Signal Input</b>                       |
| 12  | P7.4              | O0 / I | St/B | <b>Bit 4 of Port 7, General Purpose Input/Output</b> |
|     | EMUX2             | O1     | St/B | <b>External Analog MUX Control Output 2 (ADC1)</b>   |
|     | U0C1_DOUT         | O2     | St/B | <b>USIC0 Channel 1 Shift Data Output</b>             |
|     | U0C1_SCLK<br>OUT  | O3     | St/B | <b>USIC0 Channel 1 Shift Clock Output</b>            |
|     | CCU62_CCP<br>OS2A | I      | St/B | <b>CCU62 Position Input 2</b>                        |
|     | TCK_C             | I      | St/B | <b>DAP0/JTAG Clock Input</b>                         |
|     | U0C0_DX0D         | I      | St/B | <b>USIC0 Channel 0 Shift Data Input</b>              |
|     | U0C1_DX1E         | I      | St/B | <b>USIC0 Channel 1 Shift Clock Input</b>             |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol         | Ctrl.  | Type | Function                                             |
|-----|----------------|--------|------|------------------------------------------------------|
| 13  | P8.1           | O0 / I | St/B | <b>Bit 1 of Port 8, General Purpose Input/Output</b> |
|     | CCU60_CC6_1    | O1     | St/B | <b>CCU60 Channel 1 Output</b>                        |
|     | CCU60_CC6_1INB | I      | St/B | <b>CCU60 Channel 1 Input</b>                         |
|     | RxDC1F         | I      | St/B | <b>CAN Node 1 Receive Data Input</b>                 |
| 14  | P8.0           | O0 / I | St/B | <b>Bit 0 of Port 8, General Purpose Input/Output</b> |
|     | CCU60_CC6_0    | O1     | St/B | <b>CCU60 Channel 0 Output</b>                        |
|     | CCU60_CC6_0INB | I      | St/B | <b>CCU60 Channel 0 Input</b>                         |
| 16  | P6.0           | O0 / I | St/A | <b>Bit 0 of Port 6, General Purpose Input/Output</b> |
|     | EMUX0          | O1     | St/A | <b>External Analog MUX Control Output 0 (ADC0)</b>   |
|     | <u>BRKOUT</u>  | O3     | St/A | <b>OCDS Break Signal Output</b>                      |
|     | ADCx_REQG_TyG  | I      | St/A | <b>External Request Gate Input for ADC0/1</b>        |
|     | U1C1_DX0E      | I      | St/A | <b>USIC1 Channel 1 Shift Data Input</b>              |
| 17  | P6.1           | O0 / I | St/A | <b>Bit 1 of Port 6, General Purpose Input/Output</b> |
|     | EMUX1          | O1     | St/A | <b>External Analog MUX Control Output 1 (ADC0)</b>   |
|     | T3OUT          | O2     | St/A | <b>GPT12E Timer T3 Toggle Latch Output</b>           |
|     | U1C1_DOUT      | O3     | St/A | <b>USIC1 Channel 1 Shift Data Output</b>             |
|     | ADCx_REQT_RyE  | I      | St/A | <b>External Request Trigger Input for ADC0/1</b>     |
|     | ESR1_6         | I      | St/A | <b>ESR1 Trigger Input 6</b>                          |
| 18  | P6.2           | O0 / I | St/A | <b>Bit 2 of Port 6, General Purpose Input/Output</b> |
|     | EMUX2          | O1     | St/A | <b>External Analog MUX Control Output 2 (ADC0)</b>   |
|     | T6OUT          | O2     | St/A | <b>GPT12E Timer T6 Toggle Latch Output</b>           |
|     | U1C1_SCLK_OUT  | O3     | St/A | <b>USIC1 Channel 1 Shift Clock Output</b>            |
|     | U1C1_DX1C      | I      | St/A | <b>USIC1 Channel 1 Shift Clock Input</b>             |

## Parallel Ports

Table 9-18 Pin Definitions and Functions (cont'd)

| Pin | Symbol           | Ctrl.  | Type | Function                                              |
|-----|------------------|--------|------|-------------------------------------------------------|
| 19  | P6.3             | O0 / I | St/A | <b>Bit 3 of Port 6, General Purpose Input/Output</b>  |
|     | T3OUT            | O2     | St/A | <b>GPT12E Timer T3 Toggle Latch Output</b>            |
|     | U1C1_SELO<br>0   | O3     | St/A | <b>USIC1 Channel 1 Select/Control 0 Output</b>        |
|     | U1C1_DX2D        | I      | St/A | <b>USIC1 Channel 1 Shift Control Input</b>            |
|     | ADCx_REQT<br>RyF | I      | St/A | <b>External Request Trigger Input for ADC0/1</b>      |
| 21  | P15.0            | I      | In/A | <b>Bit 0 of Port 15, General Purpose Input</b>        |
|     | ADC1_CH0         | I      | In/A | <b>Analog Input Channel 0 for ADC1</b>                |
| 22  | P15.1            | I      | In/A | <b>Bit 1 of Port 15, General Purpose Input</b>        |
|     | ADC1_CH1         | I      | In/A | <b>Analog Input Channel 1 for ADC1</b>                |
| 23  | P15.2            | I      | In/A | <b>Bit 2 of Port 15, General Purpose Input</b>        |
|     | ADC1_CH2         | I      | In/A | <b>Analog Input Channel 2 for ADC1</b>                |
|     | T5INA            | I      | In/A | <b>GPT12E Timer T5 Count/Gate Input</b>               |
| 24  | P15.3            | I      | In/A | <b>Bit 3 of Port 15, General Purpose Input</b>        |
|     | ADC1_CH3         | I      | In/A | <b>Analog Input Channel 3 for ADC1</b>                |
|     | T5EUDA           | I      | In/A | <b>GPT12E Timer T5 External Up/Down Control Input</b> |
| 25  | P15.4            | I      | In/A | <b>Bit 4 of Port 15, General Purpose Input</b>        |
|     | ADC1_CH4         | I      | In/A | <b>Analog Input Channel 4 for ADC1</b>                |
|     | T6INA            | I      | In/A | <b>GPT12E Timer T6 Count/Gate Input</b>               |
| 26  | P15.5            | I      | In/A | <b>Bit 5 of Port 15, General Purpose Input</b>        |
|     | ADC1_CH5         | I      | In/A | <b>Analog Input Channel 5 for ADC1</b>                |
|     | T6EUDA           | I      | In/A | <b>GPT12E Timer T6 External Up/Down Control Input</b> |
| 27  | P15.6            | I      | In/A | <b>Bit 6 of Port 15, General Purpose Input</b>        |
|     | ADC1_CH6         | I      | In/A | <b>Analog Input Channel 6 for ADC1</b>                |
| 28  | P15.7            | I      | In/A | <b>Bit 7 of Port 15, General Purpose Input</b>        |
|     | ADC1_CH7         | I      | In/A | <b>Analog Input Channel 7 for ADC1</b>                |
| 29  | $V_{AREF1}$      | -      | PS/A | <b>Reference Voltage for A/D Converter ADC1</b>       |
| 30  | $V_{AREFO}$      | -      | PS/A | <b>Reference Voltage for A/D Converter ADC0</b>       |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol        | Ctrl. | Type | Function                                              |
|-----|---------------|-------|------|-------------------------------------------------------|
| 31  | $V_{AGND}$    | -     | PS/A | <b>Reference Ground for A/D Converters ADC0/1</b>     |
| 32  | P5.0          | I     | In/A | <b>Bit 0 of Port 5, General Purpose Input</b>         |
|     | ADC0_CH0      | I     | In/A | <b>Analog Input Channel 0 for ADC0</b>                |
| 33  | P5.1          | I     | In/A | <b>Bit 1 of Port 5, General Purpose Input</b>         |
|     | ADC0_CH1      | I     | In/A | <b>Analog Input Channel 1 for ADC0</b>                |
| 34  | P5.2          | I     | In/A | <b>Bit 2 of Port 5, General Purpose Input</b>         |
|     | ADC0_CH2      | I     | In/A | <b>Analog Input Channel 2 for ADC0</b>                |
|     | TDI_A         | I     | In/A | <b>JTAG Test Data Input</b>                           |
| 35  | P5.3          | I     | In/A | <b>Bit 3 of Port 5, General Purpose Input</b>         |
|     | ADC0_CH3      | I     | In/A | <b>Analog Input Channel 3 for ADC0</b>                |
|     | T3INA         | I     | In/A | <b>GPT12E Timer T3 Count/Gate Input</b>               |
| 39  | P5.4          | I     | In/A | <b>Bit 4 of Port 5, General Purpose Input</b>         |
|     | ADC0_CH4      | I     | In/A | <b>Analog Input Channel 4 for ADC0</b>                |
|     | CCU63_T12_HRB | I     | In/A | <b>External Run Control Input for T12 of CCU63</b>    |
|     | T3EUDA        | I     | In/A | <b>GPT12E Timer T3 External Up/Down Control Input</b> |
|     | TMS_A         | I     | In/A | <b>JTAG Test Mode Selection Input</b>                 |
| 40  | P5.5          | I     | In/A | <b>Bit 5 of Port 5, General Purpose Input</b>         |
|     | ADC0_CH5      | I     | In/A | <b>Analog Input Channel 5 for ADC0</b>                |
|     | CCU60_T12_HRB | I     | In/A | <b>External Run Control Input for T12 of CCU60</b>    |
| 41  | P5.6          | I     | In/A | <b>Bit 6 of Port 5, General Purpose Input</b>         |
|     | ADC0_CH6      | I     | In/A | <b>Analog Input Channel 6 for ADC0</b>                |
| 42  | P5.7          | I     | In/A | <b>Bit 7 of Port 5, General Purpose Input</b>         |
|     | ADC0_CH7      | I     | In/A | <b>Analog Input Channel 7 for ADC0</b>                |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol           | Ctrl. | Type | Function                                                      |
|-----|------------------|-------|------|---------------------------------------------------------------|
| 43  | P5.8             | I     | In/A | <b>Bit 8 of Port 5, General Purpose Input</b>                 |
|     | ADC0_CH8         | I     | In/A | <b>Analog Input Channel 8 for ADC0</b>                        |
|     | CCU6x_T12H<br>RC | I     | In/A | <b>External Run Control Input for T12 of CCU60/1/<br/>2/3</b> |
|     | CCU6x_T13H<br>RC | I     | In/A | <b>External Run Control Input for T13 of CCU60/1/<br/>2/3</b> |
|     | U2C0_DX0F        | I     | In/A | <b>USIC2 Channel 0 Shift Data Input</b>                       |
| 44  | P5.9             | I     | In/A | <b>Bit 9 of Port 5, General Purpose Input</b>                 |
|     | ADC0_CH9         | I     | In/A | <b>Analog Input Channel 9 for ADC0</b>                        |
|     | CC2_T7IN         | I     | In/A | <b>CAPCOM2 Timer T7 Count Input</b>                           |
| 45  | P5.10            | I     | In/A | <b>Bit 10 of Port 5, General Purpose Input</b>                |
|     | ADC0_CH10        | I     | In/A | <b>Analog Input Channel 10 for ADC0</b>                       |
|     | BRKIN_A          | I     | In/A | <b>OCDS Break Signal Input</b>                                |
|     | U2C1_DX0F        | I     | In/A | <b>USIC2 Channel 1 Shift Data Input</b>                       |
|     | CCU61_T13<br>HRA | I     | In/A | <b>External Run Control Input for T13 of CCU61</b>            |
| 46  | P5.11            | I     | In/A | <b>Bit 11 of Port 5, General Purpose Input</b>                |
|     | ADC0_CH11        | I     | In/A | <b>Analog Input Channel 11 for ADC0</b>                       |
| 47  | P5.12            | I     | In/A | <b>Bit 12 of Port 5, General Purpose Input</b>                |
|     | ADC0_CH12        | I     | In/A | <b>Analog Input Channel 12 for ADC0</b>                       |
| 48  | P5.13            | I     | In/A | <b>Bit 13 of Port 5, General Purpose Input</b>                |
|     | ADC0_CH13        | I     | In/A | <b>Analog Input Channel 13 for ADC0</b>                       |
|     | CCU63_T13<br>HRF | I     | In/A | <b>External Run Control Input for T13 of CCU63</b>            |
| 49  | P5.14            | I     | In/A | <b>Bit 14 of Port 5, General Purpose Input</b>                |
|     | ADC0_CH14        | I     | In/A | <b>Analog Input Channel 14 for ADC0</b>                       |
| 50  | P5.15            | I     | In/A | <b>Bit 15 of Port 5, General Purpose Input</b>                |
|     | ADC0_CH15        | I     | In/A | <b>Analog Input Channel 15 for ADC0</b>                       |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol         | Ctrl.  | Type | Function                                                                                                                                              |
|-----|----------------|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 51  | P2.12          | O0 / I | St/B | <b>Bit 12 of Port 2, General Purpose Input/Output</b>                                                                                                 |
|     | U0C0_SELO_4    | O1     | St/B | <b>USIC0 Channel 0 Select/Control 4 Output</b>                                                                                                        |
|     | U0C1_SELO_3    | O2     | St/B | <b>USIC0 Channel 1 Select/Control 3 Output</b>                                                                                                        |
|     | READY          | I      | St/B | <b>External Bus Interface READY Input</b>                                                                                                             |
| 52  | P2.11          | O0 / I | St/B | <b>Bit 11 of Port 2, General Purpose Input/Output</b>                                                                                                 |
|     | U0C0_SELO_2    | O1     | St/B | <b>USIC0 Channel 0 Select/Control 2 Output</b>                                                                                                        |
|     | U0C1_SELO_2    | O2     | St/B | <b>USIC0 Channel 1 Select/Control 2 Output</b>                                                                                                        |
|     | BHE/WRH        | OH     | St/B | <b>External Bus Interf. High-Byte Control Output</b><br>Can operate either as Byte High Enable ( <u>BHE</u> ) or as Write strobe for High Byte (WRH). |
| 53  | P11.5          | O0 / I | St/B | <b>Bit 5 of Port 11, General Purpose Input/Output</b>                                                                                                 |
|     | CCU61_CC6_0    | O1     | St/B | <b>CCU61 Channel 0 Output</b>                                                                                                                         |
|     | CCU61_COU_T63  | O2     | St/B | <b>CCU61 Channel 3 Output</b>                                                                                                                         |
|     | CCU61_CC6_0INB | I      | St/B | <b>CCU61 Channel 0 Input</b>                                                                                                                          |
| 55  | P2.0           | O0 / I | St/B | <b>Bit 0 of Port 2, General Purpose Input/Output</b>                                                                                                  |
|     | CCU63_CC6_0    | O2     | St/B | <b>CCU63 Channel 0 Output</b>                                                                                                                         |
|     | AD13           | OH / I | St/B | <b>External Bus Interface Address/Data Line 13</b>                                                                                                    |
|     | RxDC0C         | I      | St/B | <b>CAN Node 0 Receive Data Input</b>                                                                                                                  |
|     | CCU63_CC6_0INB | I      | St/B | <b>CCU63 Channel 0 Input</b>                                                                                                                          |
|     | T5INB          | I      | St/B | <b>GPT12E Timer T5 Count/Gate Input</b>                                                                                                               |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol         | Ctrl.  | Type | Function                                              |
|-----|----------------|--------|------|-------------------------------------------------------|
| 56  | P2.1           | O0 / I | St/B | <b>Bit 1 of Port 2, General Purpose Input/Output</b>  |
|     | TxD C0         | O1     | St/B | <b>CAN Node 0 Transmit Data Output</b>                |
|     | CCU63_CC6_1    | O2     | St/B | <b>CCU63 Channel 1 Output</b>                         |
|     | AD14           | OH / I | St/B | <b>External Bus Interface Address/Data Line 14</b>    |
|     | CCU63_CC6_1INB | I      | St/B | <b>CCU63 Channel 1 Input</b>                          |
|     | T5EUDB         | I      | St/B | <b>GPT12E Timer T5 External Up/Down Control Input</b> |
|     | ESR1_5         | I      | St/B | <b>ESR1 Trigger Input 5</b>                           |
| 57  | P11.4          | O0 / I | St/B | <b>Bit 4 of Port 11, General Purpose Input/Output</b> |
|     | CCU61_CC6_2    | O1     | St/B | <b>CCU61 Channel 2 Output</b>                         |
|     | CCU61_CC6_2INB | I      | St/B | <b>CCU61 Channel 0 Input</b>                          |
| 58  | P2.2           | O0 / I | St/B | <b>Bit 2 of Port 2, General Purpose Input/Output</b>  |
|     | TxD C1         | O1     | St/B | <b>CAN Node 1 Transmit Data Output</b>                |
|     | CCU63_CC6_2    | O2     | St/B | <b>CCU63 Channel 2 Output</b>                         |
|     | AD15           | OH / I | St/B | <b>External Bus Interface Address/Data Line 15</b>    |
|     | CCU63_CC6_2INB | I      | St/B | <b>CCU63 Channel 2 Input</b>                          |
|     | ESR2_5         | I      | St/B | <b>ESR2 Trigger Input 5</b>                           |
| 59  | P11.3          | O0 / I | St/B | <b>Bit 3 of Port 11, General Purpose Input/Output</b> |
|     | CCU61_COU_T63  | O1     | St/B | <b>CCU61 Channel 3 Output</b>                         |
|     | CCU61_COU_T62  | O2     | St/B | <b>CCU61 Channel 2 Output</b>                         |
|     | CCU61_T13_HRF  | I      | St/B | <b>External Run Control Input for T13 of CCU61</b>    |
| 60  | P4.0           | O0 / I | St/B | <b>Bit 0 of Port 4, General Purpose Input/Output</b>  |
|     | CC2_CC24       | O3 / I | St/B | <b>CAPCOM2 CC24IO Capture Inp./ Compare Out.</b>      |
|     | <u>CS0</u>     | OH     | St/B | <b>External Bus Interface Chip Select 0 Output</b>    |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| <b>Pin</b> | <b>Symbol</b>  | <b>Ctrl.</b> | <b>Type</b> | <b>Function</b>                                       |
|------------|----------------|--------------|-------------|-------------------------------------------------------|
| 61         | P2.3           | O0 / I       | St/B        | <b>Bit 3 of Port 2, General Purpose Input/Output</b>  |
|            | U0C0_DOUT      | O1           | St/B        | <b>USIC0 Channel 0 Shift Data Output</b>              |
|            | CCU63_COU_T63  | O2           | St/B        | <b>CCU63 Channel 3 Output</b>                         |
|            | CC2_CC16       | O3 / I       | St/B        | <b>CAPCOM2 CC16IO Capture Inp./ Compare Out.</b>      |
|            | A16            | OH           | St/B        | <b>External Bus Interface Address Line 16</b>         |
|            | ESR2_0         | I            | St/B        | <b>ESR2 Trigger Input 0</b>                           |
|            | U0C0_DX0E      | I            | St/B        | <b>USIC0 Channel 0 Shift Data Input</b>               |
|            | U0C1_DX0D      | I            | St/B        | <b>USIC0 Channel 1 Shift Data Input</b>               |
| 62         | RxDC0A         | I            | St/B        | <b>CAN Node 0 Receive Data Input</b>                  |
|            | P11.2          | O0 / I       | St/B        | <b>Bit 2 of Port 11, General Purpose Input/Output</b> |
|            | CCU61_CC6_1    | O1           | St/B        | <b>CCU61 Channel 1 Output</b>                         |
|            | CCU63_CCP_OS2A | I            | St/B        | <b>CCU63 Position Input 2</b>                         |
| 63         | CCU61_CC6_1INB | I            | St/B        | <b>CCU61 Channel 1 Input</b>                          |
|            | P4.1           | O0 / I       | St/B        | <b>Bit 1 of Port 4, General Purpose Input/Output</b>  |
|            | CC2_CC25       | O3 / I       | St/B        | <b>CAPCOM2 CC25IO Capture Inp./ Compare Out.</b>      |
|            | CS1            | OH           | St/B        | <b>External Bus Interface Chip Select 1 Output</b>    |
|            | CCU62_CCP_OS0B | I            | St/B        | <b>CCU62 Position Input 0</b>                         |
|            | T4EUDB         | I            | St/B        | <b>GPT12E Timer T4 External Up/Down Control Input</b> |
|            | ESR1_8         | I            | St/B        | <b>ESR1 Trigger Input 8</b>                           |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol         | Ctrl.  | Type | Function                                              |
|-----|----------------|--------|------|-------------------------------------------------------|
| 64  | P2.4           | O0 / I | St/B | <b>Bit 4 of Port 2, General Purpose Input/Output</b>  |
|     | U0C1_DOUT      | O1     | St/B | <b>USIC0 Channel 1 Shift Data Output</b>              |
|     | TxD0C          | O2     | St/B | <b>CAN Node 0 Transmit Data Output</b>                |
|     | CC2_CC17       | O3 / I | St/B | <b>CAPCOM2 CC17IO Capture Inp./ Compare Out.</b>      |
|     | A17            | OH     | St/B | <b>External Bus Interface Address Line 17</b>         |
|     | ESR1_0         | I      | St/B | <b>ESR1 Trigger Input 0</b>                           |
|     | U0C0_DX0F      | I      | St/B | <b>USIC0 Channel 0 Shift Data Input</b>               |
|     | RxD0C1A        | I      | St/B | <b>CAN Node 1 Receive Data Input</b>                  |
| 65  | P11.1          | O0 / I | St/B | <b>Bit 1 of Port 11, General Purpose Input/Output</b> |
|     | CCU61_COU_T61  | O1     | St/B | <b>CCU61 Channel 1 Output</b>                         |
|     | TxD0C0         | O2     | St/B | <b>CAN Node 0 Transmit Data Output</b>                |
|     | CCU63_CCP_OS1A | I      | St/B | <b>CCU63 Position Input 1</b>                         |
|     | CCU61_CTR_APD  | I      | St/B | <b>CCU61 Emergency Trap Input</b>                     |
| 66  | P11.0          | O0 / I | St/B | <b>Bit 0 of Port 11, General Purpose Input/Output</b> |
|     | CCU61_COU_T60  | O1     | St/B | <b>CCU61 Channel 0 Output</b>                         |
|     | CCU63_CCP_OS0A | I      | St/B | <b>CCU63 Position Input 0</b>                         |
|     | RxD0C0F        | I      | St/B | <b>CAN Node 0 Receive Data Input</b>                  |
|     | ESR1_7         | I      | St/B | <b>ESR1 Trigger Input 7</b>                           |
| 67  | P2.5           | O0 / I | St/B | <b>Bit 5 of Port 2, General Purpose Input/Output</b>  |
|     | U0C0_SCLK_OUT  | O1     | St/B | <b>USIC0 Channel 0 Shift Clock Output</b>             |
|     | TxD0C0         | O2     | St/B | <b>CAN Node 0 Transmit Data Output</b>                |
|     | CC2_CC18       | O3 / I | St/B | <b>CAPCOM2 CC18IO Capture Inp./ Compare Out.</b>      |
|     | A18            | OH     | St/B | <b>External Bus Interface Address Line 18</b>         |
|     | U0C0_DX1D      | I      | St/B | <b>USIC0 Channel 0 Shift Clock Input</b>              |
|     | ESR1_10        | I      | St/B | <b>ESR1 Trigger Input 10</b>                          |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol            | Ctrl.  | Type | Function                                              |
|-----|-------------------|--------|------|-------------------------------------------------------|
| 68  | P4.2              | O0 / I | St/B | <b>Bit 2 of Port 4, General Purpose Input/Output</b>  |
|     | CC2_CC26          | O3 / I | St/B | <b>CAPCOM2 CC26IO Capture Inp./ Compare Out.</b>      |
|     | CS2               | OH     | St/B | <b>External Bus Interface Chip Select 2 Output</b>    |
|     | T2INA             | I      | St/B | <b>GPT12E Timer T2 Count/Gate Input</b>               |
|     | CCU62_CCP<br>OS1B | I      | St/B | <b>CCU62 Position Input 1</b>                         |
| 69  | P2.6              | O0 / I | St/B | <b>Bit 6 of Port 2, General Purpose Input/Output</b>  |
|     | U0C0_SELO<br>0    | O1     | St/B | <b>USIC0 Channel 0 Select/Control 0 Output</b>        |
|     | U0C1_SELO<br>1    | O2     | St/B | <b>USIC0 Channel 1 Select/Control 1 Output</b>        |
|     | CC2_CC19          | O3 / I | St/B | <b>CAPCOM2 CC19IO Capture Inp./ Compare Out.</b>      |
|     | A19               | OH     | St/B | <b>External Bus Interface Address Line 19</b>         |
|     | U0C0_DX2D         | I      | St/B | <b>USIC0 Channel 0 Shift Control Input</b>            |
|     | RxDC0D            | I      | St/B | <b>CAN Node 0 Receive Data Input</b>                  |
|     | ESR2_6            | I      | St/B | <b>ESR2 Trigger Input 6</b>                           |
| 70  | P4.4              | O0 / I | St/B | <b>Bit 4 of Port 4, General Purpose Input/Output</b>  |
|     | CC2_CC28          | O3 / I | St/B | <b>CAPCOM2 CC28IO Capture Inp./ Compare Out.</b>      |
|     | CS4               | OH     | St/B | <b>External Bus Interface Chip Select 4 Output</b>    |
|     | CLKIN2            | I      | St/B | <b>Clock Signal Input 2</b>                           |
| 71  | P4.3              | O0 / I | St/B | <b>Bit 3 of Port 4, General Purpose Input/Output</b>  |
|     | U0C1_DOUT         | O1     | St/B | <b>USIC0 Channel 1 Shift Data Output</b>              |
|     | CC2_CC27          | O3 / I | St/B | <b>CAPCOM2 CC27IO Capture Inp./ Compare Out.</b>      |
|     | CS3               | OH     | St/B | <b>External Bus Interface Chip Select 3 Output</b>    |
|     | T2EUDA            | I      | St/B | <b>GPT12E Timer T2 External Up/Down Control Input</b> |
|     | CCU62_CCP<br>OS2B | I      | St/B | <b>CCU62 Position Input 2</b>                         |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| <b>Pin</b> | <b>Symbol</b>  | <b>Ctrl.</b> | <b>Type</b> | <b>Function</b>                                      |
|------------|----------------|--------------|-------------|------------------------------------------------------|
| 75         | P0.0           | O0 / I       | St/B        | <b>Bit 0 of Port 0, General Purpose Input/Output</b> |
|            | U1C0_DOUT      | O1           | St/B        | <b>USIC1 Channel 0 Shift Data Output</b>             |
|            | CCU61_CC6_0    | O3           | St/B        | <b>CCU61 Channel 0 IOutput</b>                       |
|            | A0             | OH           | St/B        | <b>External Bus Interface Address Line 0</b>         |
|            | U1C0_DX0A      | I            | St/B        | <b>USIC1 Channel 0 Shift Data Input</b>              |
|            | CCU61_CC6_0INA | I            | St/B        | <b>CCU61 Channel 0 Input</b>                         |
|            | ESR1_11        | I            | St/B        | <b>ESR1 Trigger Input 11</b>                         |
| 76         | P4.5           | O0 / I       | St/B        | <b>Bit 5 of Port 4, General Purpose Input/Output</b> |
|            | CC2_CC29       | O3 / I       | St/B        | <b>CAPCOM2 CC29IO Capture Inp./Compare Out.</b>      |
|            | CCU61_CCP_OS0A | I            | St/B        | <b>CCU61 Position Input 0</b>                        |
|            | ESR2_10        | I            | St/B        | <b>ESR2 Trigger Input 10</b>                         |
| 77         | P4.6           | O0 / I       | St/B        | <b>Bit 6 of Port 4, General Purpose Input/Output</b> |
|            | CC2_CC30       | O3 / I       | St/B        | <b>CAPCOM2 CC30IO Capture Inp./ Compare Out.</b>     |
|            | T4INA          | I            | St/B        | <b>GPT12E Timer T4 Count/Gate Input</b>              |
|            | CCU61_CCP_OS1A | I            | St/B        | <b>CCU61 Position Input 1</b>                        |
| 78         | P2.7           | O0 / I       | St/B        | <b>Bit 7 of Port 2, General Purpose Input/Output</b> |
|            | U0C1_SELO_0    | O1           | St/B        | <b>USIC0 Channel 1 Select/Control 0 Output</b>       |
|            | U0C0_SELO_1    | O2           | St/B        | <b>USIC0 Channel 0 Select/Control 1 Output</b>       |
|            | CC2_CC20       | O3 / I       | St/B        | <b>CAPCOM2 CC20IO Capture Inp./ Compare Out.</b>     |
|            | A20            | OH           | St/B        | <b>External Bus Interface Address Line 20</b>        |
|            | U0C1_DX2C      | I            | St/B        | <b>USIC0 Channel 1 Shift Control Input</b>           |
|            | RxDC1C         | I            | St/B        | <b>CAN Node 1 Receive Data Input</b>                 |
|            | ESR2_7         | I            | St/B        | <b>ESR2 Trigger Input 7</b>                          |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol         | Ctrl.  | Type | Function                                              |
|-----|----------------|--------|------|-------------------------------------------------------|
| 79  | P0.1           | O0 / I | St/B | <b>Bit 1 of Port 0, General Purpose Input/Output</b>  |
|     | U1C0_DOUT      | O1     | St/B | <b>USIC1 Channel 0 Shift Data Output</b>              |
|     | TxDC0          | O2     | St/B | <b>CAN Node 0 Transmit Data Output</b>                |
|     | CCU61_CC6_1    | O3     | St/B | <b>CCU61 Channel 1 Output</b>                         |
|     | A1             | OH     | St/B | <b>External Bus Interface Address Line 1</b>          |
|     | U1C0_DX0B      | I      | St/B | <b>USIC1 Channel 0 Shift Data Input</b>               |
|     | CCU61_CC6_1INA | I      | St/B | <b>CCU61 Channel 1 Input</b>                          |
| 80  | U1C0_DX1A      | I      | St/B | <b>USIC1 Channel 0 Shift Clock Input</b>              |
|     | P2.8           | O0 / I | DP/B | <b>Bit 8 of Port 2, General Purpose Input/Output</b>  |
|     | U0C1_SCLK_OUT  | O1     | DP/B | <b>USIC0 Channel 1 Shift Clock Output</b>             |
|     | EXTCLK         | O2     | DP/B | <b>Programmable Clock Signal Output</b><br>1)         |
|     | CC2_CC21       | O3 / I | DP/B | <b>CAPCOM2 CC21IO Capture Inp./ Compare Out.</b>      |
|     | A21            | OH     | DP/B | <b>External Bus Interface Address Line 21</b>         |
| 81  | U0C1_DX1D      | I      | DP/B | <b>USIC0 Channel 1 Shift Clock Input</b>              |
|     | P4.7           | O0 / I | St/B | <b>Bit 7 of Port 4, General Purpose Input/Output</b>  |
|     | CC2_CC31       | O3 / I | St/B | <b>CAPCOM2 CC31IO Capture Inp./ Compare Out.</b>      |
|     | T4EUDA         | I      | St/B | <b>GPT12E Timer T4 External Up/Down Control Input</b> |
| 82  | CCU61_CCP_OS2A | I      | St/B | <b>CCU61 Position Input 2</b>                         |
|     | P2.9           | O0 / I | St/B | <b>Bit 9 of Port 2, General Purpose Input/Output</b>  |
|     | U0C1_DOUT      | O1     | St/B | <b>USIC0 Channel 1 Shift Data Output</b>              |
|     | TxDC1          | O2     | St/B | <b>CAN Node 1 Transmit Data Output</b>                |
|     | CC2_CC22       | O3 / I | St/B | <b>CAPCOM2 CC22IO Capture Inp./ Compare Out.</b>      |
|     | A22            | OH     | St/B | <b>External Bus Interface Address Line 22</b>         |
|     | CLKIN1         | I      | St/B | <b>Clock Signal Input 1</b>                           |
|     | TCK_A          | I      | St/B | <b>DAP0/JTAG Clock Input</b>                          |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol         | Ctrl.  | Type | Function                                              |
|-----|----------------|--------|------|-------------------------------------------------------|
| 83  | P0.2           | O0 / I | St/B | <b>Bit 2 of Port 0, General Purpose Input/Output</b>  |
|     | U1C0_SCLK OUT  | O1     | St/B | <b>USIC1 Channel 0 Shift Clock Output</b>             |
|     | TxD0           | O2     | St/B | <b>CAN Node 0 Transmit Data Output</b>                |
|     | CCU61_CC6_2    | O3     | St/B | <b>CCU61 Channel 2 Output</b>                         |
|     | A2             | OH     | St/B | <b>External Bus Interface Address Line 2</b>          |
|     | U1C0_DX1B      | I      | St/B | <b>USIC1 Channel 0 Shift Clock Input</b>              |
|     | CCU61_CC6_2INA | I      | St/B | <b>CCU61 Channel 2 Input</b>                          |
| 84  | P10.0          | O0 / I | St/B | <b>Bit 0 of Port 10, General Purpose Input/Output</b> |
|     | U0C1_DOUT      | O1     | St/B | <b>USIC0 Channel 1 Shift Data Output</b>              |
|     | CCU60_CC6_0    | O2     | St/B | <b>CCU60 Channel 0 Output</b>                         |
|     | AD0            | OH / I | St/B | <b>External Bus Interface Address/Data Line 0</b>     |
|     | CCU60_CC6_0INA | I      | St/B | <b>CCU60 Channel 0 Input</b>                          |
|     | ESR1_2         | I      | St/B | <b>ESR1 Trigger Input 2</b>                           |
|     | U0C0_DX0A      | I      | St/B | <b>USIC0 Channel 0 Shift Data Input</b>               |
| 85  | U0C1_DX0A      | I      | St/B | <b>USIC0 Channel 1 Shift Data Input</b>               |
|     | P3.0           | O0 / I | St/B | <b>Bit 0 of Port 3, General Purpose Input/Output</b>  |
|     | U2C0_DOUT      | O1     | St/B | <b>USIC2 Channel 0 Shift Data Output</b>              |
|     | BREQ           | OH     | St/B | <b>External Bus Request Output</b>                    |
|     | ESR1_1         | I      | St/B | <b>ESR1 Trigger Input 1</b>                           |
|     | U2C0_DX0A      | I      | St/B | <b>USIC2 Channel 0 Shift Data Input</b>               |
|     | U2C0_DX1A      | I      | St/B | <b>USIC2 Channel 0 Shift Clock Input</b>              |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol         | Ctrl.  | Type | Function                                                                                         |
|-----|----------------|--------|------|--------------------------------------------------------------------------------------------------|
| 86  | P10.1          | O0 / I | St/B | <b>Bit 1 of Port 10, General Purpose Input/Output</b>                                            |
|     | U0C0_DOUT      | O1     | St/B | <b>USIC0 Channel 0 Shift Data Output</b>                                                         |
|     | CCU60_CC6_1    | O2     | St/B | <b>CCU60 Channel 1 Output</b>                                                                    |
|     | AD1            | OH / I | St/B | <b>External Bus Interface Address/Data Line 1</b>                                                |
|     | CCU60_CC6_1INA | I      | St/B | <b>CCU60 Channel 1 Input</b>                                                                     |
|     | U0C0_DX0B      | I      | St/B | <b>USIC0 Channel 0 Shift Data Input</b>                                                          |
|     | U0C0_DX1A      | I      | St/B | <b>USIC0 Channel 0 Shift Clock Input</b>                                                         |
| 87  | P0.3           | O0 / I | St/B | <b>Bit 3 of Port 0, General Purpose Input/Output</b>                                             |
|     | U1C0_SELO_0    | O1     | St/B | <b>USIC1 Channel 0 Select/Control 0 Output</b>                                                   |
|     | U1C1_SELO_1    | O2     | St/B | <b>USIC1 Channel 1 Select/Control 1 Output</b>                                                   |
|     | CCU61_COUT60   | O3     | St/B | <b>CCU61 Channel 0 Output</b>                                                                    |
|     | A3             | OH     | St/B | <b>External Bus Interface Address Line 3</b>                                                     |
|     | U1C0_DX2A      | I      | St/B | <b>USIC1 Channel 0 Shift Control Input</b>                                                       |
|     | RxDC0B         | I      | St/B | <b>CAN Node 0 Receive Data Input</b>                                                             |
| 88  | P3.1           | O0 / I | St/B | <b>Bit 1 of Port 3, General Purpose Input/Output</b>                                             |
|     | U2C0_DOUT      | O1     | St/B | <b>USIC2 Channel 0 Shift Data Output</b>                                                         |
|     | HLDA           | OH / I | St/B | <b>External Bus Hold Acknowledge Output/Input</b><br>Output in master mode, input in slave mode. |
|     | U2C0_DX0B      | I      | St/B | <b>USIC2 Channel 0 Shift Data Input</b>                                                          |
| 89  | P10.2          | O0 / I | St/B | <b>Bit 2 of Port 10, General Purpose Input/Output</b>                                            |
|     | U0C0_SCLK_OUT  | O1     | St/B | <b>USIC0 Channel 0 Shift Clock Output</b>                                                        |
|     | CCU60_CC6_2    | O2     | St/B | <b>CCU60 Channel 2 Output</b>                                                                    |
|     | AD2            | OH / I | St/B | <b>External Bus Interface Address/Data Line 2</b>                                                |
|     | CCU60_CC6_2INA | I      | St/B | <b>CCU60 Channel 2 Input</b>                                                                     |
|     | U0C0_DX1B      | I      | St/B | <b>USIC0 Channel 0 Shift Clock Input</b>                                                         |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol        | Ctrl.  | Type | Function                                              |
|-----|---------------|--------|------|-------------------------------------------------------|
| 90  | P0.4          | O0 / I | St/B | <b>Bit 4 of Port 0, General Purpose Input/Output</b>  |
|     | U1C1_SELO_0   | O1     | St/B | <b>USIC1 Channel 1 Select/Control 0 Output</b>        |
|     | U1C0_SELO_1   | O2     | St/B | <b>USIC1 Channel 0 Select/Control 1 Output</b>        |
|     | CCU61_COU_T61 | O3     | St/B | <b>CCU61 Channel 1 Output</b>                         |
|     | A4            | OH     | St/B | <b>External Bus Interface Address Line 4</b>          |
|     | U1C1_DX2A     | I      | St/B | <b>USIC1 Channel 1 Shift Control Input</b>            |
|     | RxDC1B        | I      | St/B | <b>CAN Node 1 Receive Data Input</b>                  |
|     | ESR2_8        | I      | St/B | <b>ESR2 Trigger Input 8</b>                           |
| 92  | P2.13         | O0 / I | St/B | <b>Bit 13 of Port 2, General Purpose Input/Output</b> |
|     | U2C1_SELO_2   | O1     | St/B | <b>USIC2 Channel 1 Select/Control 2 Output</b>        |
| 93  | P3.2          | O0 / I | St/B | <b>Bit 2 of Port 3, General Purpose Input/Output</b>  |
|     | U2C0_SCLK_OUT | O1     | St/B | <b>USIC2 Channel 0 Shift Clock Output</b>             |
|     | U2C0_DX1B     | I      | St/B | <b>USIC2 Channel 0 Shift Clock Input</b>              |
|     | HOLD          | I      | St/B | <b>External Bus Master Hold Request Input</b>         |
| 94  | P2.10         | O0 / I | St/B | <b>Bit 10 of Port 2, General Purpose Input/Output</b> |
|     | U0C1_DOUT     | O1     | St/B | <b>USIC0 Channel 1 Shift Data Output</b>              |
|     | U0C0_SELO_3   | O2     | St/B | <b>USIC0 Channel 0 Select/Control 3 Output</b>        |
|     | CC2_CC23      | O3 / I | St/B | <b>CAPCOM2 CC23IO Capture Inp./ Compare Out.</b>      |
|     | A23           | OH     | St/B | <b>External Bus Interface Address Line 23</b>         |
|     | U0C1_DX0E     | I      | St/B | <b>USIC0 Channel 1 Shift Data Input</b>               |
|     | CAPINA        | I      | St/B | <b>GPT12E Register CAPREL Capture Input</b>           |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol        | Ctrl.  | Type | Function                                              |
|-----|---------------|--------|------|-------------------------------------------------------|
| 95  | P10.3         | O0 / I | St/B | <b>Bit 3 of Port 10, General Purpose Input/Output</b> |
|     | CCU60_COU_T60 | O2     | St/B | <b>CCU60 Channel 0 Output</b>                         |
|     | AD3           | OH / I | St/B | <b>External Bus Interface Address/Data Line 3</b>     |
|     | U0C0_DX2A     | I      | St/B | <b>USIC0 Channel 0 Shift Control Input</b>            |
|     | U0C1_DX2A     | I      | St/B | <b>USIC0 Channel 1 Shift Control Input</b>            |
| 96  | P0.5          | O0 / I | St/B | <b>Bit 5 of Port 0, General Purpose Input/Output</b>  |
|     | U1C1_SCLK_OUT | O1     | St/B | <b>USIC1 Channel 1 Shift Clock Output</b>             |
|     | U1C0_SELO_2   | O2     | St/B | <b>USIC1 Channel 0 Select/Control 2 Output</b>        |
|     | CCU61_COU_T62 | O3     | St/B | <b>CCU61 Channel 2 Output</b>                         |
|     | A5            | OH     | St/B | <b>External Bus Interface Address Line 5</b>          |
|     | U1C1_DX1A     | I      | St/B | <b>USIC1 Channel 1 Shift Clock Input</b>              |
|     | U1C0_DX1C     | I      | St/B | <b>USIC1 Channel 0 Shift Clock Input</b>              |
| 97  | P3.3          | O0 / I | St/B | <b>Bit 3 of Port 3, General Purpose Input/Output</b>  |
|     | U2C0_SELO_0   | O1     | St/B | <b>USIC2 Channel 0 Select/Control 0 Output</b>        |
|     | U2C1_SELO_1   | O2     | St/B | <b>USIC2 Channel 1 Select/Control 1 Output</b>        |
|     | U2C0_DX2A     | I      | St/B | <b>USIC2 Channel 0 Shift Control Input</b>            |
| 98  | P10.4         | O0 / I | St/B | <b>Bit 4 of Port 10, General Purpose Input/Output</b> |
|     | U0C0_SELO_3   | O1     | St/B | <b>USIC0 Channel 0 Select/Control 3 Output</b>        |
|     | CCU60_COU_T61 | O2     | St/B | <b>CCU60 Channel 1 Output</b>                         |
|     | AD4           | OH / I | St/B | <b>External Bus Interface Address/Data Line 4</b>     |
|     | U0C0_DX2B     | I      | St/B | <b>USIC0 Channel 0 Shift Control Input</b>            |
|     | U0C1_DX2B     | I      | St/B | <b>USIC0 Channel 1 Shift Control Input</b>            |
|     | ESR1_9        | I      | St/B | <b>ESR1 Trigger Input 9</b>                           |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol        | Ctrl.  | Type | Function                                              |
|-----|---------------|--------|------|-------------------------------------------------------|
| 99  | P3.4          | O0 / I | St/B | <b>Bit 4 of Port 3, General Purpose Input/Output</b>  |
|     | U2C1_SELO_0   | O1     | St/B | <b>USIC2 Channel 1 Select/Control 0 Output</b>        |
|     | U2C0_SELO_1   | O2     | St/B | <b>USIC2 Channel 0 Select/Control 1 Output</b>        |
|     | U0C0_SELO_4   | O3     | St/B | <b>USIC0 Channel 0 Select/Control 4 Output</b>        |
|     | U2C1_DX2A     | I      | St/B | <b>USIC2 Channel 1 Shift Control Input</b>            |
| 100 | P10.5         | O0 / I | St/B | <b>Bit 5 of Port 10, General Purpose Input/Output</b> |
|     | U0C1_SCLK_OUT | O1     | St/B | <b>USIC0 Channel 1 Shift Clock Output</b>             |
|     | CCU60_COU_T62 | O2     | St/B | <b>CCU60 Channel 2 Output</b>                         |
|     | U2C0_DOUT     | O3     | St/B | <b>USIC2 Channel 0 Shift Data Output</b>              |
|     | AD5           | OH / I | St/B | <b>External Bus Interface Address/Data Line 5</b>     |
|     | U0C1_DX1B     | I      | St/B | <b>USIC0 Channel 1 Shift Clock Input</b>              |
| 101 | P3.5          | O0 / I | St/B | <b>Bit 5 of Port 3, General Purpose Input/Output</b>  |
|     | U2C1_SCLK_OUT | O1     | St/B | <b>USIC2 Channel 1 Shift Clock Output</b>             |
|     | U2C0_SELO_2   | O2     | St/B | <b>USIC2 Channel 0 Select/Control 2 Output</b>        |
|     | U0C0_SELO_5   | O3     | St/B | <b>USIC0 Channel 0 Select/Control 5 Output</b>        |
|     | U2C1_DX1A     | I      | St/B | <b>USIC2 Channel 1 Shift Clock Input</b>              |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol           | Ctrl.  | Type | Function                                              |
|-----|------------------|--------|------|-------------------------------------------------------|
| 102 | P0.6             | O0 / I | St/B | <b>Bit 6 of Port 0, General Purpose Input/Output</b>  |
|     | U1C1_DOUT        | O1     | St/B | <b>USIC1 Channel 1 Shift Data Output</b>              |
|     | TxDC1            | O2     | St/B | <b>CAN Node 1 Transmit Data Output</b>                |
|     | CCU61_COU<br>T63 | O3     | St/B | <b>CCU61 Channel 3 Output</b>                         |
|     | A6               | OH     | St/B | <b>External Bus Interface Address Line 6</b>          |
|     | U1C1_DX0A        | I      | St/B | <b>USIC1 Channel 1 Shift Data Input</b>               |
|     | CCU61_CTR<br>APA | I      | St/B | <b>CCU61 Emergency Trap Input</b>                     |
|     | U1C1_DX1B        | I      | St/B | <b>USIC1 Channel 1 Shift Clock Input</b>              |
| 103 | P10.6            | O0 / I | St/B | <b>Bit 6 of Port 10, General Purpose Input/Output</b> |
|     | U0C0_DOUT        | O1     | St/B | <b>USIC0 Channel 0 Shift Data Output</b>              |
|     | U1C0_SELO<br>0   | O3     | St/B | <b>USIC1 Channel 0 Select/Control 0 Output</b>        |
|     | AD6              | OH / I | St/B | <b>External Bus Interface Address/Data Line 6</b>     |
|     | U0C0_DX0C        | I      | St/B | <b>USIC0 Channel 0 Shift Data Input</b>               |
|     | U1C0_DX2D        | I      | St/B | <b>USIC1 Channel 0 Shift Control Input</b>            |
|     | CCU60_CTR<br>APA | I      | St/B | <b>CCU60 Emergency Trap Input</b>                     |
| 104 | P3.6             | O0 / I | St/B | <b>Bit 6 of Port 3, General Purpose Input/Output</b>  |
|     | U2C1_DOUT        | O1     | St/B | <b>USIC2 Channel 1 Shift Data Output</b>              |
|     | U0C0_SELO<br>6   | O3     | St/B | <b>USIC0 Channel 0 Select/Control 6 Output</b>        |
|     | U2C1_DX0A        | I      | St/B | <b>USIC2 Channel 1 Shift Data Input</b>               |
|     | U2C1_DX1B        | I      | St/B | <b>USIC2 Channel 1 Shift Clock Input</b>              |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol         | Ctrl.  | Type | Function                                              |
|-----|----------------|--------|------|-------------------------------------------------------|
| 105 | P10.7          | O0 / I | St/B | <b>Bit 7 of Port 10, General Purpose Input/Output</b> |
|     | U0C1_DOUT      | O1     | St/B | <b>USIC0 Channel 1 Shift Data Output</b>              |
|     | CCU60_COU_T63  | O2     | St/B | <b>CCU60 Channel 3 Output</b>                         |
|     | AD7            | OH / I | St/B | <b>External Bus Interface Address/Data Line 7</b>     |
|     | U0C1_DX0B      | I      | St/B | <b>USIC0 Channel 1 Shift Data Input</b>               |
|     | CCU60_CCP_OS0A | I      | St/B | <b>CCU60 Position Input 0</b>                         |
|     | T4INB          | I      | St/B | <b>GPT12E Timer T4 Count/Gate Input</b>               |
| 106 | P0.7           | O0 / I | St/B | <b>Bit 7 of Port 0, General Purpose Input/Output</b>  |
|     | U1C1_DOUT      | O1     | St/B | <b>USIC1 Channel 1 Shift Data Output</b>              |
|     | U1C0_SELO_3    | O2     | St/B | <b>USIC1 Channel 0 Select/Control 3 Output</b>        |
|     | A7             | OH     | St/B | <b>External Bus Interface Address Line 7</b>          |
|     | U1C1_DX0B      | I      | St/B | <b>USIC1 Channel 1 Shift Data Input</b>               |
|     | CCU61_CTR_APB  | I      | St/B | <b>CCU61 Emergency Trap Input</b>                     |
| 107 | P3.7           | O0 / I | St/B | <b>Bit 7 of Port 3, General Purpose Input/Output</b>  |
|     | U2C1_DOUT      | O1     | St/B | <b>USIC2 Channel 1 Shift Data Output</b>              |
|     | U2C0_SELO_3    | O2     | St/B | <b>USIC2 Channel 0 Select/Control 3 Output</b>        |
|     | U0C0_SELO_7    | O3     | St/B | <b>USIC0 Channel 0 Select/Control 7 Output</b>        |
|     | U2C1_DX0B      | I      | St/B | <b>USIC2 Channel 1 Shift Data Input</b>               |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol         | Ctrl.  | Type | Function                                              |
|-----|----------------|--------|------|-------------------------------------------------------|
| 111 | P1.0           | O0 / I | St/B | <b>Bit 0 of Port 1, General Purpose Input/Output</b>  |
|     | U1C0_MCLK OUT  | O1     | St/B | <b>USIC1 Channel 0 Master Clock Output</b>            |
|     | U1C0_SELO 4    | O2     | St/B | <b>USIC1 Channel 0 Select/Control 4 Output</b>        |
|     | A8             | OH     | St/B | <b>External Bus Interface Address Line 8</b>          |
|     | ESR1_3         | I      | St/B | <b>ESR1 Trigger Input 3</b>                           |
|     | CCU62_CTR APB  | I      | St/B | <b>CCU62 Emergency Trap Input</b>                     |
|     | T6INB          | I      | St/B | <b>GPT12E Timer T6 Count/Gate Input</b>               |
| 112 | P9.0           | O0 / I | St/B | <b>Bit 0 of Port 9, General Purpose Input/Output</b>  |
|     | CCU63_CC6 0    | O1     | St/B | <b>CCU63 Channel 0 Output</b>                         |
|     | CCU63_CC6 0INA | I      | St/B | <b>CCU63 Channel 0 Input</b>                          |
|     | T6EUDB         | I      | St/B | <b>GPT12E Timer T6 External Up/Down Control Input</b> |
| 113 | P10.8          | O0 / I | St/B | <b>Bit 8 of Port 10, General Purpose Input/Output</b> |
|     | U0C0_MCLK OUT  | O1     | St/B | <b>USIC0 Channel 0 Master Clock Output</b>            |
|     | U0C1_SELO 0    | O2     | St/B | <b>USIC0 Channel 1 Select/Control 0 Output</b>        |
|     | U2C1_DOUT      | O3     | St/B | <b>USIC2 Channel 1 Shift Data Output</b>              |
|     | AD8            | OH / I | St/B | <b>External Bus Interface Address/Data Line 8</b>     |
|     | CCU60_CCP OS1A | I      | St/B | <b>CCU60 Position Input 1</b>                         |
|     | U0C0_DX1C      | I      | St/B | <b>USIC0 Channel 0 Shift Clock Input</b>              |
|     | BRKIN_B        | I      | St/B | <b>OCDS Break Signal Input</b>                        |
|     | T3EUDB         | I      | St/B | <b>GPT12E Timer T3 External Up/Down Control Input</b> |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol         | Ctrl.  | Type | Function                                               |
|-----|----------------|--------|------|--------------------------------------------------------|
| 114 | P9.1           | O0 / I | St/B | <b>Bit 1 of Port 9, General Purpose Input/Output</b>   |
|     | CCU63_CC6_1    | O1     | St/B | <b>CCU63 Channel 1 Output</b>                          |
|     | CCU63_CC6_1INA | I      | St/B | <b>CCU63 Channel 1 Input</b>                           |
| 115 | P10.9          | O0 / I | St/B | <b>Bit 9 of Port 10, General Purpose Input/Output</b>  |
|     | U0C0_SELO_4    | O1     | St/B | <b>USIC0 Channel 0 Select/Control 4 Output</b>         |
|     | U0C1_MCLK_OUT  | O2     | St/B | <b>USIC0 Channel 1 Master Clock Output</b>             |
|     | AD9            | OH / I | St/B | <b>External Bus Interface Address/Data Line 9</b>      |
|     | CCU60_CCP_OS2A | I      | St/B | <b>CCU60 Position Input 2</b>                          |
|     | TCK_B          | I      | St/B | <b>DAP0/JTAG Clock Input</b>                           |
| 116 | T3INB          | I      | St/B | <b>GPT12E Timer T3 Count/Gate Input</b>                |
|     | P1.1           | O0 / I | St/B | <b>Bit 1 of Port 1, General Purpose Input/Output</b>   |
|     | CCU62_COU_T62  | O1     | St/B | <b>CCU62 Channel 2 Output</b>                          |
|     | U1C0_SELO_5    | O2     | St/B | <b>USIC1 Channel 0 Select/Control 5 Output</b>         |
|     | U2C1_DOUT      | O3     | St/B | <b>USIC2 Channel 1 Shift Data Output</b>               |
|     | A9             | OH     | St/B | <b>External Bus Interface Address Line 9</b>           |
|     | ESR2_3         | I      | St/B | <b>ESR2 Trigger Input 3</b>                            |
| 117 | U2C1_DX0C      | I      | St/B | <b>USIC2 Channel 1 Shift Data Input</b>                |
|     | P10.10         | O0 / I | St/B | <b>Bit 10 of Port 10, General Purpose Input/Output</b> |
|     | U0C0_SELO_0    | O1     | St/B | <b>USIC0 Channel 0 Select/Control 0 Output</b>         |
|     | CCU60_COU_T63  | O2     | St/B | <b>CCU60 Channel 3 Output</b>                          |
|     | AD10           | OH / I | St/B | <b>External Bus Interface Address/Data Line 10</b>     |
|     | U0C0_DX2C      | I      | St/B | <b>USIC0 Channel 0 Shift Control Input</b>             |
|     | TDI_B          | I      | St/B | <b>JTAG Test Data Input</b>                            |
|     | U0C1_DX1A      | I      | St/B | <b>USIC0 Channel 1 Shift Clock Input</b>               |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol         | Ctrl.  | Type | Function                                               |
|-----|----------------|--------|------|--------------------------------------------------------|
| 118 | P10.11         | O0 / I | St/B | <b>Bit 11 of Port 10, General Purpose Input/Output</b> |
|     | U1C0_SCLK OUT  | O1     | St/B | <b>USIC1 Channel 0 Shift Clock Output</b>              |
|     | BRKOUT         | O2     | St/B | <b>OCDS Break Signal Output</b>                        |
|     | AD11           | OH / I | St/B | <b>External Bus Interface Address/Data Line 11</b>     |
|     | U1C0_DX1D      | I      | St/B | <b>USIC1 Channel 0 Shift Clock Input</b>               |
|     | TMS_B          | I      | St/B | <b>JTAG Test Mode Selection Input</b>                  |
| 119 | P9.2           | O0 / I | St/B | <b>Bit 2 of Port 9, General Purpose Input/Output</b>   |
|     | CCU63_CC6_2    | O1     | St/B | <b>CCU63 Channel 2 Output</b>                          |
|     | CCU63_CC6_2INA | I      | St/B | <b>CCU63 Channel 2 Input</b>                           |
|     | CAPINB         | I      | St/B | <b>GPT12E Register CAPREL Capture Input</b>            |
| 120 | P1.2           | O0 / I | St/B | <b>Bit 2 of Port 1, General Purpose Input/Output</b>   |
|     | CCU62_CC6_2    | O1     | St/B | <b>CCU62 Channel 2 Output</b>                          |
|     | U1C0_SELO_6    | O2     | St/B | <b>USIC1 Channel 0 Select/Control 6 Output</b>         |
|     | U2C1_SCLK OUT  | O3     | St/B | <b>USIC2 Channel 1 Shift Clock Output</b>              |
|     | A10            | OH     | St/B | <b>External Bus Interface Address Line 10</b>          |
|     | ESR1_4         | I      | St/B | <b>ESR1 Trigger Input 4</b>                            |
|     | CCU61_T12_HRB  | I      | St/B | <b>External Run Control Input for T12 of CCU61</b>     |
|     | CCU62_CC6_2INA | I      | St/B | <b>CCU62 Channel 2 Input</b>                           |
|     | U2C1_DX0D      | I      | St/B | <b>USIC2 Channel 1 Shift Data Input</b>                |
|     | U2C1_DX1C      | I      | St/B | <b>USIC2 Channel 1 Shift Clock Input</b>               |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol        | Ctrl.  | Type | Function                                                                                                                                                               |
|-----|---------------|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 121 | P10.12        | O0 / I | St/B | <b>Bit 12 of Port 10, General Purpose Input/Output</b>                                                                                                                 |
|     | U1C0_DOUT     | O1     | St/B | <b>USIC1 Channel 0 Shift Data Output</b>                                                                                                                               |
|     | TDO_B         | OH     | St/B | <b>DAP1/JTAG Test Data Output</b>                                                                                                                                      |
|     | AD12          | OH / I | St/B | <b>External Bus Interface Address/Data Line 12</b>                                                                                                                     |
|     | U1C0_DX0C     | I      | St/B | <b>USIC1 Channel 0 Shift Data Input</b>                                                                                                                                |
|     | U1C0_DX1E     | I      | St/B | <b>USIC1 Channel 0 Shift Clock Input</b>                                                                                                                               |
| 122 | P9.3          | O0 / I | St/B | <b>Bit 3 of Port 9, General Purpose Input/Output</b>                                                                                                                   |
|     | CCU63_COU_T60 | O1     | St/B | <b>CCU63 Channel 0 Output</b>                                                                                                                                          |
|     | <u>BRKOUT</u> | O2     | St/B | <b>OCDS Break Signal Output</b>                                                                                                                                        |
| 123 | P10.13        | O0 / I | St/B | <b>Bit 13 of Port 10, General Purpose Input/Output</b>                                                                                                                 |
|     | U1C0_DOUT     | O1     | St/B | <b>USIC1 Channel 0 Shift Data Output</b>                                                                                                                               |
|     | U1C0_SELO_3   | O3     | St/B | <b>USIC1 Channel 0 Select/Control 3 Output</b>                                                                                                                         |
|     | <u>WR/WRL</u> | OH     | St/B | <b>External Bus Interface Write Strobe Output</b><br>Active for each external write access, when <u>WR</u> , active for ext. writes to the low byte, when <u>WRL</u> . |
|     | U1C0_DX0D     | I      | St/B | <b>USIC1 Channel 0 Shift Data Input</b>                                                                                                                                |
| 124 | P1.3          | O0 / I | St/B | <b>Bit 3 of Port 1, General Purpose Input/Output</b>                                                                                                                   |
|     | CCU62_COU_T63 | O1     | St/B | <b>CCU62 Channel 3 Output</b>                                                                                                                                          |
|     | U1C0_SELO_7   | O2     | St/B | <b>USIC1 Channel 0 Select/Control 7 Output</b>                                                                                                                         |
|     | U2C0_SELO_4   | O3     | St/B | <b>USIC2 Channel 0 Select/Control 4 Output</b>                                                                                                                         |
|     | A11           | OH     | St/B | <b>External Bus Interface Address Line 11</b>                                                                                                                          |
|     | ESR2_4        | I      | St/B | <b>ESR2 Trigger Input 4</b>                                                                                                                                            |
|     | CCU62_T12_HRB | I      | St/B | <b>External Run Control Input for T12 of CCU62</b>                                                                                                                     |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol         | Ctrl.  | Type | Function                                               |
|-----|----------------|--------|------|--------------------------------------------------------|
| 125 | P9.4           | O0 / I | St/B | <b>Bit 4 of Port 9, General Purpose Input/Output</b>   |
|     | CCU63_COU_T61  | O1     | St/B | <b>CCU63 Channel 1 Output</b>                          |
|     | U2C0_DOUT      | O2     | St/B | <b>USIC2 Channel 0 Shift Data Output</b>               |
|     | CCU62_COU_T63  | O3     | St/B | <b>CCU62 Channel 3 Output</b>                          |
| 126 | P9.5           | O0 / I | St/B | <b>Bit 5 of Port 9, General Purpose Input/Output</b>   |
|     | CCU63_COU_T62  | O1     | St/B | <b>CCU63 Channel 2 Output</b>                          |
|     | U2C0_DOUT      | O2     | St/B | <b>USIC2 Channel 0 Shift Data Output</b>               |
|     | CCU62_COU_T62  | O3     | St/B | <b>CCU62 Channel 2 Output</b>                          |
|     | U2C0_DX0E      | I      | St/B | <b>USIC2 Channel 0 Shift Data Input</b>                |
|     | CCU60_CCP_OS2B | I      | St/B | <b>CCU60 Position Input 2</b>                          |
| 128 | P10.14         | O0 / I | St/B | <b>Bit 14 of Port 10, General Purpose Input/Output</b> |
|     | U1C0_SELO_1    | O1     | St/B | <b>USIC1 Channel 0 Select/Control 1 Output</b>         |
|     | U0C1_DOUT      | O2     | St/B | <b>USIC0 Channel 1 Shift Data Output</b>               |
|     | RD             | OH     | St/B | <b>External Bus Interface Read Strobe Output</b>       |
|     | ESR2_2         | I      | St/B | <b>ESR2 Trigger Input 2</b>                            |
|     | U0C1_DX0C      | I      | St/B | <b>USIC0 Channel 1 Shift Data Input</b>                |
| 129 | P1.4           | O0 / I | St/B | <b>Bit 4 of Port 1, General Purpose Input/Output</b>   |
|     | CCU62_COU_T61  | O1     | St/B | <b>CCU62 Channel 1 Output</b>                          |
|     | U1C1_SELO_4    | O2     | St/B | <b>USIC1 Channel 1 Select/Control 4 Output</b>         |
|     | U2C0_SELO_5    | O3     | St/B | <b>USIC2 Channel 0 Select/Control 5 Output</b>         |
|     | A12            | OH     | St/B | <b>External Bus Interface Address Line 12</b>          |
|     | U2C0_DX2B      | I      | St/B | <b>USIC2 Channel 0 Shift Control Input</b>             |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol         | Ctrl.  | Type | Function                                               |
|-----|----------------|--------|------|--------------------------------------------------------|
| 130 | P10.15         | O0 / I | St/B | <b>Bit 15 of Port 10, General Purpose Input/Output</b> |
|     | U1C0_SELO_2    | O1     | St/B | <b>USIC1 Channel 0 Select/Control 2 Output</b>         |
|     | U0C1_DOUT      | O2     | St/B | <b>USIC0 Channel 1 Shift Data Output</b>               |
|     | U1C0_DOUT      | O3     | St/B | <b>USIC1 Channel 0 Shift Data Output</b>               |
|     | ALE            | OH     | St/B | <b>External Bus Interf. Addr. Latch Enable Output</b>  |
|     | U0C1_DX1C      | I      | St/B | <b>USIC0 Channel 1 Shift Clock Input</b>               |
| 131 | P1.5           | O0 / I | St/B | <b>Bit 5 of Port 1, General Purpose Input/Output</b>   |
|     | CCU62_COU_T60  | O1     | St/B | <b>CCU62 Channel 0 Output</b>                          |
|     | U1C1_SELO_3    | O2     | St/B | <b>USIC1 Channel 1 Select/Control 3 Output</b>         |
|     | BRKOUT         | O3     | St/B | <b>OCDS Break Signal Output</b>                        |
|     | A13            | OH     | St/B | <b>External Bus Interface Address Line 13</b>          |
|     | U2C0_DX0C      | I      | St/B | <b>USIC2 Channel 0 Shift Data Input</b>                |
| 132 | P9.6           | O0 / I | St/B | <b>Bit 6 of Port 9, General Purpose Input/Output</b>   |
|     | CCU63_COU_T63  | O1     | St/B | <b>CCU63 Channel 3 Output</b>                          |
|     | CCU63_COU_T62  | O2     | St/B | <b>CCU63 Channel 2 Output</b>                          |
|     | CCU62_COU_T61  | O3     | St/B | <b>CCU62 Channel 1 Output</b>                          |
|     | CCU63_CTRAPA   | I      | St/B | <b>CCU63 Emergency Trap Input</b>                      |
|     | CCU60_CCP_OS1B | I      | St/B | <b>CCU60 Position Input 1</b>                          |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol         | Ctrl.  | Type | Function                                             |
|-----|----------------|--------|------|------------------------------------------------------|
| 133 | P1.6           | O0 / I | St/B | <b>Bit 6 of Port 1, General Purpose Input/Output</b> |
|     | CCU62_CC6_1    | O1 / I | St/B | <b>CCU62 Channel 1 Output</b>                        |
|     | U1C1_SELO_2    | O2     | St/B | <b>USIC1 Channel 1 Select/Control 2 Output</b>       |
|     | U2C0_DOUT      | O3     | St/B | <b>USIC2 Channel 0 Shift Data Output</b>             |
|     | A14            | OH     | St/B | <b>External Bus Interface Address Line 14</b>        |
|     | U2C0_DX0D      | I      | St/B | <b>USIC2 Channel 0 Shift Data Input</b>              |
|     | CCU62_CC6_1INA | I      | St/B | <b>CCU62 Channel 1 Input</b>                         |
| 134 | P9.7           | O0 / I | St/B | <b>Bit 7 of Port 9, General Purpose Input/Output</b> |
|     | CCU62_COUT60   | O1     | St/B | <b>CCU62 Channel 0 Output</b>                        |
|     | CCU62_COUT63   | O2     | St/B | <b>CCU62 Channel 3 Output</b>                        |
|     | CCU63_CTR_APB  | I      | St/B | <b>CCU63 Emergency Trap Input</b>                    |
|     | U2C0_DX1D      | I      | St/B | <b>USIC2 Channel 0 Shift Clock Input</b>             |
|     | CCU60_CCP_OS0B | I      | St/B | <b>CCU60 Position Input 0</b>                        |
| 135 | P1.7           | O0 / I | St/B | <b>Bit 7 of Port 1, General Purpose Input/Output</b> |
|     | CCU62_CC6_0    | O1     | St/B | <b>CCU62 Channel 0 Output</b>                        |
|     | U1C1_MCLK_OUT  | O2     | St/B | <b>USIC1 Channel 1 Master Clock Output</b>           |
|     | U2C0_SCLK_OUT  | O3     | St/B | <b>USIC2 Channel 0 Shift Clock Output</b>            |
|     | A15            | OH     | St/B | <b>External Bus Interface Address Line 15</b>        |
|     | U2C0_DX1C      | I      | St/B | <b>USIC2 Channel 0 Shift Clock Input</b>             |
|     | CCU62_CC6_0INA | I      | St/B | <b>CCU62 Channel 0 Input</b>                         |
| 136 | XTAL2          | O      | Sp/1 | <b>Crystal Oscillator Amplifier Output</b>           |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin | Symbol    | Ctrl.  | Type | Function                                                                                                                                                                                                                                                                                                                         |
|-----|-----------|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 137 | XTAL1     | I      | Sp/1 | <b>Crystal Oscillator Amplifier Input</b><br>To clock the device from an external source, drive XTAL1, while leaving XTAL2 unconnected.<br>Voltages on XTAL1 must comply to the core supply voltage $V_{DDI1}$ .                                                                                                                 |
|     | ESR2_9    | I      | St/B | <b>ESR2 Trigger Input 9</b>                                                                                                                                                                                                                                                                                                      |
| 138 | PORST     | I      | In/B | <b>Power On Reset Input</b><br>A low level at this pin resets the XC27x5X completely. A spike filter suppresses input pulses <10 ns. Input pulses >100 ns safely pass the filter. The minimum duration for a safe recognition should be 120 ns.<br>An internal pullup device will hold this pin high when nothing is driving it. |
| 139 | ESR1      | O0 / I | St/B | <b>External Service Request 1</b>                                                                                                                                                                                                                                                                                                |
|     | RxDC0E    | I      | St/B | <b>CAN Node 0 Receive Data Input</b>                                                                                                                                                                                                                                                                                             |
|     | U1C0_DX0F | I      | St/B | <b>USIC1 Channel 0 Shift Data Input</b>                                                                                                                                                                                                                                                                                          |
|     | U1C0_DX2C | I      | St/B | <b>USIC1 Channel 0 Shift Control Input</b>                                                                                                                                                                                                                                                                                       |
|     | U1C1_DX0C | I      | St/B | <b>USIC1 Channel 1 Shift Data Input</b>                                                                                                                                                                                                                                                                                          |
|     | U1C1_DX2B | I      | St/B | <b>USIC1 Channel 1 Shift Control Input</b>                                                                                                                                                                                                                                                                                       |
|     | U2C1_DX2C | I      | St/B | <b>USIC2 Channel 1 Shift Control Input</b>                                                                                                                                                                                                                                                                                       |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| <b>Pin</b> | <b>Symbol</b> | <b>Ctrl.</b> | <b>Type</b> | <b>Function</b>                                                                                                                        |
|------------|---------------|--------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 140        | ESR2          | O0 / I       | St/B        | <b>External Service Request 2</b>                                                                                                      |
|            | RxDC1E        | I            | St/B        | <b>CAN Node 1 Receive Data Input</b>                                                                                                   |
|            | CCU60_CTR_APB | I            | St/B        | <b>CCU60 Emergency Trap Input</b>                                                                                                      |
|            | CCU61_CTR_APB | I            | St/B        | <b>CCU61 Emergency Trap Input</b>                                                                                                      |
|            | CCU62_CTR_APB | I            | St/B        | <b>CCU62 Emergency Trap Input</b>                                                                                                      |
|            | CCU63_CTR_APB | I            | St/B        | <b>CCU63 Emergency Trap Input</b>                                                                                                      |
|            | U1C1_DX0D     | I            | St/B        | <b>USIC1 Channel 1 Shift Data Input</b>                                                                                                |
|            | U1C1_DX2C     | I            | St/B        | <b>USIC1 Channel 1 Shift Control Input</b>                                                                                             |
|            | U2C1_DX0E     | I            | St/B        | <b>USIC2 Channel 1 Shift Data Input</b>                                                                                                |
|            | U2C1_DX2B     | I            | St/B        | <b>USIC2 Channel 1 Shift Control Input</b>                                                                                             |
| 141        | ESR0          | O0 / I       | St/B        | <b>External Service Request 0</b><br><i>Note: After power-up, ESR0 operates as open-drain bidirectional reset with a weak pull-up.</i> |
|            | U1C0_DX0E     | I            | St/B        | <b>USIC1 Channel 0 Shift Data Input</b>                                                                                                |
|            | U1C0_DX2B     | I            | St/B        | <b>USIC1 Channel 0 Shift Control Input</b>                                                                                             |
| 142        | P8.6          | O0 / I       | St/B        | <b>Bit 6 of Port 8, General Purpose Input/Output</b>                                                                                   |
|            | CCU60_COU_T63 | O1           | St/B        | <b>CCU60 Channel 3 Output</b>                                                                                                          |
|            | MCHK_MAT_CH   | O3           | St/B        | <b>Memory Checker Match Output</b>                                                                                                     |
|            | CCU60_CTR_APB | I            | St/B        | <b>CCU60 Emergency Trap Input</b>                                                                                                      |
|            | BRKIN_D       | I            | St/B        | <b>OCDS Break Signal Input</b>                                                                                                         |
|            | CCU62_CTR_APD | I            | St/B        | <b>CCU62 Emergency Trap Input</b>                                                                                                      |

## Parallel Ports

**Table 9-18 Pin Definitions and Functions (cont'd)**

| Pin                                                   | Symbol         | Ctrl.  | Type  | Function                                                                                                                                                                                                                                                                                       |
|-------------------------------------------------------|----------------|--------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 143                                                   | P8.5           | O0 / I | St/B  | <b>Bit 5 of Port 8, General Purpose Input/Output</b>                                                                                                                                                                                                                                           |
|                                                       | CCU60_COU_T62  | O1     | St/B  | <b>CCU60 Channel 2 Output</b>                                                                                                                                                                                                                                                                  |
|                                                       | CCU62_CC6_2    | O2     | St/B  | <b>CCU62 Channel 2 Output</b>                                                                                                                                                                                                                                                                  |
|                                                       | TCK_D          | I      | St/B  | <b>DAP0/JTAG Clock Input</b>                                                                                                                                                                                                                                                                   |
|                                                       | CCU62_CC6_2INB | I      | St/B  | <b>CCU62 Channel 2 Input</b>                                                                                                                                                                                                                                                                   |
| 15                                                    | $V_{DDIM}$     | -      | PS/M  | <b>Digital Core Supply Voltage for Domain M</b><br>Decouple with a ceramic capacitor, see Data Sheet for details.                                                                                                                                                                              |
| 54,<br>91,<br>127                                     | $V_{DDI1}$     | -      | PS/1  | <b>Digital Core Supply Voltage for Domain 1</b><br>Decouple with a ceramic capacitor, see Data Sheet for details.<br>All $V_{DDI1}$ pins must be connected to each other.                                                                                                                      |
| 20                                                    | $V_{DDPA}$     | -      | PS/A  | <b>Digital Pad Supply Voltage for Domain A</b><br>Connect decoupling capacitors to adjacent $V_{DDP}/V_{SS}$ pin pairs as close as possible to the pins.<br><i>Note: The A/D_Converters and ports P5, P6 and P15 are fed from supply voltage <math>V_{DDPA}</math>.</i>                        |
| 2,<br>36,<br>38,<br>72,<br>74,<br>108,<br>110,<br>144 | $V_{DDPB}$     | -      | PS/B  | <b>Digital Pad Supply Voltage for Domain B</b><br>Connect decoupling capacitors to adjacent $V_{DDP}/V_{SS}$ pin pairs as close as possible to the pins.<br><i>Note: The on-chip voltage regulators and all ports except P5, P6 and P15 are fed from supply voltage <math>V_{DDPB}</math>.</i> |
| 1,<br>37,<br>73,<br>109                               | $V_{SS}$       | -      | PS/-- | <b>Digital Ground</b><br>All $V_{SS}$ pins must be connected to the ground-line or ground-plane.                                                                                                                                                                                               |

<sup>1)</sup> To generate the reference clock output for bus timing measurement,  $f_{SYS}$  must be selected as source for EXTCLK and P2.8 must be selected as output pin. Also the high-speed clock pad must be enabled. This configuration is referred to as reference clock output signal CLKOUT.

## Dedicated Pins

### 10 Dedicated Pins

Most of the input/output or control signals of the functional the XC27x5X are realized as alternate functions of pins of the parallel ports. There is, however, a number of signals that use separate pins, including the oscillator, special control signals and, of course, the power supply.

**Table 10-1** summarizes the dedicated pins of the XC27x5X.

**Table 10-1 XC27x5X Dedicated Pins**

| Pin(s)                   | Function                                               |
|--------------------------|--------------------------------------------------------|
| PORST                    | Power-On Reset Input                                   |
| ESR0                     | External Service Request Input 0                       |
| ESR1                     | External Service Request Input 1                       |
| ESR2                     | External Service Request Input 2                       |
| XTAL1, XTAL2             | Oscillator Input/Output (main oscillator)              |
| TESTM                    | Test Mode Enable                                       |
| TRST                     | Test-System Reset Input                                |
| $V_{AREFx}$ , $V_{AGND}$ | Reference voltages for the Analog/Digital Converter(s) |
| $V_{DDIM}$               | Digital Core Supply for Domain M (1 pin)               |
| $V_{DDI1}$               | Digital Core Supply for Domain 1 (3 pins)              |
| $V_{DDPA}$               | Digital Pad Supply for Domain A including ADCs (1 pin) |
| $V_{DDPB}$               | Digital Pad Supply for Domain B (8 pins)               |
| $V_{SS}$                 | Digital Ground (4 pins)                                |

**The Power-On Reset Input PORST** allows to put the XC27x5X into the well defined reset condition either at power-up or external events like a hardware failure or manual reset.

**The External Service Request Inputs ESR0, ESR1, and ESR2** can be used for several system-related functions:

- trigger interrupt or trap (Class A or Class B) requests via an external signal (e.g. a power-fail signal)
- generate wake-up request signals
- generate hardware reset requests (**ESR0** is bidirectional by default, **ESR1** and **ESR2** can optionally output a reset signal)
- data/control input for CCU6x, MultiCAN, and USIC (**ESR1** or **ESR2**)
- software-controlled input/output signal

## Dedicated Pins

**The Oscillator Input XTAL1 and Output XTAL2** connect the internal **Main Oscillator** to the external crystal. The oscillator provides an inverter and a feedback element. The standard external oscillator circuitry comprises the crystal, two low end capacitors and series resistor to limit the current through the crystal. The main oscillator is intended for the generation of a high-precision operating clock signal for the XC27x5X.

An external clock signal may be fed to the input XTAL1, leaving XTAL2 open. The current logic state of input XTAL1 can be read via a status flag, so XTAL1 can be used as digital input if neither the oscillator interface nor the clock input is required.

*Note: Pin XTAL1 belongs to the core power domain DMP\_M. All input signals, therefore, must be within the core voltage range.*

**The Test Mode Input TESTM** puts the XC27x5X into a test mode, which is used during the production tests of the device. In test mode, the XC27x5X behaves different from normal operation. Therefore, pin TESTM must be held HIGH (connect to  $V_{DDPB}$ ) for normal operation in an application system.

**The Test Reset Input TRST** puts the XC27x5X's debug system into reset state. During normal operation this input should be held low. For debugging purposes the on-chip debugging system can be enabled by driving pin TRST high at the rising edge of PORST.

**The Analog Reference Voltage Supply pins**  $V_{AREFx}$  and  $V_{AGND}$  provide separate reference voltage for the on-chip Analog/Digital-Converter(s). This reduces the noise that is coupled to the analog input signals from the digital logic sections and so improves the stability of the conversion results, when  $V_{AREF}$  and  $V_{AGND}$  are properly decoupled from  $V_{DD}$  and  $V_{SS}$ . Also, because conversion results are generated in relation to the reference voltages, ratiometric conversions are easily achieved.

*Note: Channel 0 of each module can be used as an alternate reference voltage input.*

**The Core Supply pins**  $V_{DDIM}/V_{DDI1}$  serve two purposes: While the on-chip EVVRs provide the power for the core logic of the XC27x5X these pins connect the EVVRs to their external buffer capacitors. For external supply, the core voltage is applied to these pins. The respective  $V_{DD}/V_{SS}$  pairs should be decoupled as close to the pins as possible. Use ceramic capacitors and observe their values recommended in the respective Data Sheet.

**The Power Supply pins**  $V_{DDPA}/V_{DDPB}$  provide the power supply for all the analog and digital logic of the XC27x5X. Each power domain (DMP\_A and DMP\_B) can be supplied with an arbitrary voltage within the specified supply voltage range (please refer to the corresponding Data Sheets). These pins supply the output drivers as well as the on-chip EVVRs ( $V_{DDPB}$ ), except for external core voltage supply. The respective  $V_{DD}/V_{SS}$  pairs should be decoupled as close to the pins as possible.

## Dedicated Pins

**The Ground Reference pins**  $V_{SS}$  provide the ground reference voltage for the power supplies as well as the reference voltage for the input signals.

*Note: All  $V_{DDx}$  pins and all  $V_{SS}$  pins must be connected to the power supplies and ground, respectively.*

## 11 External Bus Controller (EBC)

The EBC enables the C166SV2 CPU access to chip external and internal peripherals and memories. The access can be of program fetch type or data exchange. If used to interface to the chip external world the external bus is also referred to as EXTBUS if used with internal (local) components it is also referred to as LXBUS.

### 11.1 Summary of Features

The EBC functional and timing behavior is widely configurable so that it can be tailored to fit into a large range of applications.

- Demultiplexed and multiplexed mode of operation
- Up to 24 address lines
- 8-bit or 16-bit data bus
- Synchronous and asynchronous ready
- External bus arbitration support
- Up to 8 bus channels
- Address window programmable for up to 7 channels
- Bus timing and function programmable for each channel

### 11.2 Overview

The function and timing characteristics of the EBC are controlled by a set of configuration registers.

The basic and general behavior is programmed via the mode selection registers EBCMOD0 and EBCMOD1.

The EBC supports up to eight ( $x=0\dots7$ ) bus channels linked to a dedicated chip select (CS $x$ ). Each channel is programmable by a dedicated set of registers. The FCONCS $x$  registers specify the functional characteristics while the TCONCS $x$  registers specify the cycle timing. The address area assigned to a channel is definable for seven channels by the ADDRSEL(1...7) registers. The remaining uncovered address areas are assigned to CS0.

External CS $x$  signals can be used in order to save external glue logic. Access to non timing deterministic external devices is supported by a particular READY functionality. A HOLD/HLDA protocol is available for bus arbitration.

The external bus timing is related to the reference CLocK OUTput (CLKOUT) signal. All bus signals are generated in relation to the rising edge of this clock. The external bus protocol is compatible with those of the C166 family. However, the external bus timing is improved in terms of wait state granularity and signal flexibility.

## 11.3 Naming Conventions

For description of EBC timing and functions the following bus signal names will be used.

Control signals:

- ALE - Address Latch Enable (high active). Indicates that the applied address is valid.
- CS - Chip select.
- WR/WRL - Write Strobe, Write Low Byte Strobe (low active). Configured either to a general write request or a write request for the low byte.
- BHE/WRH - Byte High Enable, Write High Byte Strobe (low active). Configured either to an enable for the high byte or a write request for the high byte.
- RD - Read Strobe (low active).
- READY - Ready to indicate end of actions (programmable polarity).
- HOLD - Hold input for foreign bus requests (low active).
- HLDA - Hold Acknowledge (low active), master output to grant bus.
- BREQ - Bus Request (low active).

Bus signals:

- A or ADDR - Address bus.
- D or DATA - Data bus.
- AD - Shared Data/Address[15:0] bus.

## 11.4 Timing Description

Bus characteristics can be programmed to the following access modes:

- 16-bit data bus with address not multiplexed
- 16-bit data bus with address multiplexed
- 8-bit data bus with address not multiplexed
- 8-bit data bus with address multiplexed

Multiplexed mode means that the data bus is used in a time multiplex mode for address (16 LSB only) and for data. In demultiplexed mode the data bus is used for data only and an additional address bus must be made available.

### 11.4.1 Bus Phases

The external bus timing is defined by six different timing phases (A-F). These phases influence the control signals needed for any access sequence to a bus device.

At the beginning of a phase the output signals change within a defined output delay time. The particular delay times are specified in the XC27x5X data book. After the output delay the values of the control output signals are stable within this phase. Each phase can occupy a programmable number of CLKOUT cycles.

## A Phase - CS Change Phase

The A phase can take 0-3 clocks. It is used for tristating databus drivers from the previous cycle (tristate wait states after chip select switch).

A phase cycles are not inserted at every access cycle, but only when changing the CS. If an access using one CS (CSx) ends and the next access with a different CS (CSy) is started, then A phase cycles are performed according to the bits set in the **first** CS (CSx). This feature is used to optimize wait states with devices having a long turn-off delay at their databus drivers, such as EPROMs and flash memories.

The A phase cycles are inserted while the addresses and ALE of the next cycle are already applied.

If there are some idle cycles between two accesses, these clocks are taken into account and the A phase is shortened accordingly. For example, if there are three tristate cycles programmed and two idle cycles occur, then the A phase takes only one clock.

## B Phase - Address Setup / ALE Phase

The B phase can take 1-2 clocks. It is used for addressing devices before giving a command, and defines the length of time that ALE is active. In multiplexed bus mode, the address is applied for latching.

## C Phase - Delay Phase

The C phase is similar to the A and B phases but ALE is already low. It can take 0-3 clocks. In multiplexed bus mode, the address is held in order to be latched safely. Phase C cycles can be used to delay the command signals (RW delay).

## D Phase - Write Data Setup / Mux Tristate Phase

The D phase can take 0-1 clocks. It is used to tristate the address on the multiplexed bus when a read cycle is performed. For all write cycles, it is used to ensure that the data are valid on the bus before the command is applied.

## E Phase - RD/WR Command Phase

The E phase is the command or access phase, and takes 1-32 clocks. Read data are fetched, write data are put onto the bus, and the command signals are active. Read data are registered with the terminating clock of this phase.

The READY function lengthens this phase, too. READY-controlled access cycles may have an unlimited cycle time.

## F Phase - Address / Write Data Hold Phase

The F phase is at the end of an access. It can take 0-3 clocks.

Addresses and write data are held while the command is inactive. The number of wait states inserted during the F phase is independently programmable for read and write

## External Bus Controller (EBC)

accesses. The F phase is used to program tristate wait states on the bidirectional data bus in order to avoid bus conflicts.

### 11.4.2 Demultiplexed Bus

General timing diagrams of a read and a write demultiplexed access are shown below.



**Figure 11-1 Demultiplexed Bus Read**



**Figure 11-2 Demultiplexed Bus Write**

- A phase: Addresses valid, ALE high, no command.  $\overline{CS}$  switch tristate wait states
- B phase: Addresses valid, ALE high, no command. ALE length
- C phase: Addresses valid, ALE low, no command. R/W delay
- D phase: Write data valid, ALE low, no command. Data valid for write cycles
- E phase: Command (read or write) active. Access time
- F phase: Command inactive, address hold. Read data tristate time, write data hold time

### 11.4.3 Multiplexed Bus

General timing diagrams of a read and a write multiplexed access are shown below.



Figure 11-3 Multiplexed Bus Read



Figure 11-4 Multiplexed Bus Write

- A phase: addresses valid, ALE high, no command.  $\overline{CS}$  switch tristate wait states
- B phase: addresses valid, ALE high, no command. ALE length
- C phase: addresses valid, ALE low, no command. Address hold, R/W delay
- D phase: address tristate for read cycles, data valid for write cycles, ALE low, no command
- E phase: command (read or write) active. Access time

**External Bus Controller (EBC)**

- F phase: command inactive, address hold. Read data tristate time, write data hold time.

#### 11.4.4 Fastest Access Cycles

The fastest possible bus cycle in a system depends also on the pad timing. Therefore, the number of required cycles for a bus access depends on the current system frequency. The minimum bus cycles shown below cannot be achieved at very high system frequencies.



**Figure 11-5 Fastest Read Cycle Demultiplexed Bus**



**Figure 11-6 Fastest Write Cycle Demultiplexed Bus**

## External Bus Controller (EBC)


**Figure 11-7 Fastest Read Cycle Multiplexed Bus**

**Figure 11-8 Fastest Write Cycle Multiplexed Bus**

## 11.5 Address Windows

The EBC provides up to 8 logical bus channels. For 7 of these (assigned to CS1...CS7) the allocated address window can be programmed by the ADDRSEL(1...7) registers. The remaining channel (assigned to CS0) has no address select register assigned and covers the remaining EBC address space.

Note that not the complete XC27x5X address space can be accessed by the EBC. For an overview on allocation of the complete address space please refer to the “Memory Organization” chapter.

### 11.5.1 Window Allocation

The size and start address of an address window is defined according to [Table 11-1](#). The size of the window is chosen by ADDRSELx.RGSZ. Depending on the size the relevant bits of ADDRSELx.RGSAD (marked with ‘R’) are used to select the corresponding window start address. The lower bits of ADDRSELx.RGSAD (marked ‘x’) are disregarded.

A programmed address windows must additionally be enabled by setting the corresponding FCONCSx.ENCS bit.

**Table 11-1 Address Range and Size for ADDRSELx**

| ADDRSELx        |                            | Address Window         |                                                           |
|-----------------|----------------------------|------------------------|-----------------------------------------------------------|
| Range Size RGSZ | Relevant (R) Bits of RGSAD | Selected Address Range | Range Start Address A[23:0] Selected with R-bits of RGSAD |
| 3 ... 0         | 15 ... 4                   | Size                   | A23 ... A0                                                |
| 0000            | RRRR RRRR RRRR             | 4 Kbytes               | RRRR RRRR RRRR 0000 0000 0000                             |
| 0001            | RRRR RRRR RRRx             | 8 Kbytes               | RRRR RRRR RRR0 0000 0000 0000                             |
| 0010            | RRRR RRRR RRxx             | 16 Kbytes              | RRRR RRRR RR00 0000 0000 0000                             |
| 0011            | RRRR RRRR Rxss             | 32 Kbytes              | RRRR RRRR R000 0000 0000 0000                             |
| 0100            | RRRR RRRR xxxx             | 64 Kbytes              | RRRR RRRR 0000 0000 0000 0000                             |
| 0101            | RRRR RRRx xxxx             | 128 Kbytes             | RRRR RRR0 0000 0000 0000 0000                             |
| 0110            | RRRR RRxx xxxx             | 256 Kbytes             | RRRR RR00 0000 0000 0000 0000                             |
| 0111            | RRRR Rxxx xxxx             | 512 Kbytes             | RRRR R000 0000 0000 0000 0000                             |
| 1000            | RRRR xxxx xxxx             | 1 Mbytes               | RRRR 0000 0000 0000 0000 0000                             |
| 1001            | RRRx xxxx xxxx             | 2 Mbytes               | RRR0 0000 0000 0000 0000 0000                             |
| 1010            | RRxx xxxx xxxx             | 4 Mbytes               | RR00 0000 0000 0000 0000 0000                             |
| 1011            | Rxxx xxxx xxxx             | 8 Mbytes               | R000 0000 0000 0000 0000 0000                             |
| 11xx            | xxxx xxxx xxxx             | reserved               | -----                                                     |

### 11.5.2 Window Overlap

Since it is possible to program overlapping address areas an arbitration scheme is defined to handle these cases. For each access directed to the EBC it compares the current address with all address select registers of enabled windows. This comparison is done in three levels.

#### Priority 1:

Registers ADDRSEL $x$  [ $x = 2, 4, 6$ ] of enabled windows are evaluated first. Upon a match the access starts on the respective channel. Overlap of windows within this group will lead to undefined behavior.

#### Priority 2:

Registers ADDRSEL $y$  [ $y = 1, 3, 5, 7$ ] of enabled windows are evaluated in this step. Upon a match the access starts on the respective channel. Overlap of windows within this group will lead to undefined behavior. Overlaps with priority 1 ADDRSEL $x$  are only allowed for the ( $x,y$ ) pairs (2,1), (4,3) and (6, 5).

#### Priority 3:

If channel 0 is enabled the access is directed to it. Otherwise no bus action occurs.

## 11.6 Ready Controlled Bus Access

In cases, where the response time of a peripheral is not constant, or where the programmable wait states are not enough, the XC27x5X EBC provides the so called READY controlled bus access scheme.

In this scheme bus accesses are terminated by the READY input signal. During phase E the EBC first counts a programmable number of clock cycles (1...32) and then starts in the last wait cycle to monitor the internal READY line ("READY Int" in [Figure 11-9](#)) to determine the actual end of the current bus cycle. The external device drives READY active in order to indicate that data has been latched (write cycle) or is available (read cycle).

A READY controlled bus cycle requires one synchronization cycle to terminate. Programmed phase F cycles include this synchronization cycle. Therefore setting TCONCSx phase F to 0 clock cycles will have the same effect as setting to 1 clock cycle.

### 11.6.1 Enabling the Ready Control

The READY pin is enabled by setting the bit RDYDIS in EBCMOD0 to '0' in order to activate the corresponding port pin. The polarity of the READY is also defined inside the EBCMOD0 register by the RDYPOL bit.

For a specific address window the READY function is enabled via the RDYEN bit in the FCONCSx register. By programming of FCONCSx.RDYMOD the READY is handled either in synchronous or in asynchronous mode (see also [Figure 11-9](#)).

When the READY function is enabled for a specific address window, each bus cycle within this window must be cleanly terminated with an active READY signal. Otherwise the EBC will be completely blocked by this pending access.



Figure 11-9 External to internal READY conversion

### 11.6.2 Synchronous and Asynchronous READY

The synchronous READY provides the fastest bus cycles, but requires setup and hold times to be met. The CLKOUT signal should be enabled and may be used by the peripheral logic to control the READY timing in this case.

## External Bus Controller (EBC)

The asynchronous READY is less restrictive, but requires one additional wait state caused by the internal synchronization. As the asynchronous READY is sampled earlier programmed wait states may be necessary to provide proper bus cycles

A READY signal (especially asynchronous READY) that has been activated by an external device should be deactivated in response to the trailing (rising) edge of the respective command (RD or WR).



Figure 11-10 Ready controlled bus cycles

### 11.6.3 Combining the READY function with predefined wait states

Typically an external wait state or READY control logic takes a while to generate the READY signal when a cycle was started. After a predefined number of clock cycles the XC27x5X will start checking its READY line to determine the end of the bus cycle.

When using the READY function with so-called ‘normally-ready’ peripherals, it may lead to erroneous bus cycles, if the READY line is sampled too early. These peripherals pull their READY output active, while they are idle. When they are accessed, they drive READY inactive until the bus cycle is complete, then drive it active again. If, however, the peripheral drives READY inactive a little late, after the first sample point of the XC27x5X, the controller samples an active READY and terminates the current bus cycle too early. By inserting predefined wait states the first READY sample point can be shifted to a time, where the peripheral has safely controlled the READY line.

## 11.7 External Bus Arbitration

The XC27x5X supports multi master systems on the external bus by its external bus arbitration. This bus arbitration allows an external master to request the external bus. The XC27x5X will release the external bus and will float the data and address bus lines and force the control signals via pull ups/downs to their inactive state.

**Attention:** *This feature is only available if the memory protection unit (MPU) is disabled.*

### 11.7.1 Initialization of Arbitration

During reset all arbitration pins are tristate, except pin BREQ which is pulled inactive. After reset the XC27x5X EBC always starts in ‘init mode’ where the external bus is available but no arbitration is enabled. All arbitration pins are ignored in this state. Other to the external bus connected XC27x5X EBCs assume to have the bus also, so potential bus conflicts are not resolved. For a multi master system the arbitration should be initialized first before starting any bus access. The EBC can either be chosen as arbitration master or as arbitration slave by programming the EBCMOD0 bit SLAVE. The selected mode and the arbitration gets active by the first setting of the HLDEN bit inside the CPUs PSW register. Afterwards a change of the slave/master mode is not possible without resetting the device. Of course for arbitration the dedicated pins have to be activated by setting EBCMOD0.ARBEN.

### 11.7.2 Arbitration Master Scheme

If the XC27x5X EBC is configured as arbitration master, it is default owner of the external bus, controls the arbitration protocol and drives the bus also during idle phases with no bus requests. To perform the arbitration handshake a HOLD input allows the request of the external bus from the arbitration master. When the arbitration master hands over the bus to the requester this is signaled by driving the hold acknowledge pin HLDA low, which remains at this level until the arbitration slave frees the bus by releasing its request on the HOLD input. If the arbitration master is not the owner of the bus it treats the external bus interface as follows:

- Address and data bus(es) float to tristate
- Command lines are pulled high by internal pull-up devices (RD, WR/WRL, BHE/WRH)
- Address latch control line ALE is pulled low by an internal pull-down device
- CSx outputs are pulled high by internal pull-up devices.

In this state the arbitration slave can take over the bus.

If the arbitration master requires the bus again, it can request the bus via the bus request signal BREQ. As soon as the arbitration master regains the bus it releases the BREQ signal and drives HLDA to high.



**Figure 11-11 Releasing the Bus by the Arbitration Master**

*Note: The figure above shows the first possibility for **BREQ** to get active. The XC27x5X will complete the currently running bus cycle before granting the external bus as indicated by the broken lines.*



**Figure 11-12 Regaining the Bus by the Arbitration Master**

*Note: The falling **BREQ** edge shows the last chance for **BREQ** to trigger the indicated regain-sequence. Even if **BREQ** is activated earlier the regain-sequence is initiated by **HOLD** going high. Please note that **HOLD** may also be deactivated without the XC27x5X requesting the bus.*

### 11.7.3 Arbitration Slave Scheme

If the EBC is configured as arbitration slave it is by default not owner of the external bus and has to request the bus first. As long as it has not finished all its queued requests and the arbitration master is not requesting the bus the arbitration slave stays owner of the bus. For the description of the signal handling of the handshake see [Chapter 11.7.2](#). For the arbitration slave the hold acknowledge pin **HLDA** is configured as input.

### 11.7.4 Bus Lock Function

If an application in a multi master system requires a sequence of undisturbed bus access it has the possibility (independently of being arbitration slave or master) to lock<sup>1)</sup> the bus by setting the PSW bit **HLDEN** to '0'. In this case the looked EBC will not answer to **HOLD** requests from other external bus master until **HLDEN** is set to '1' again. Of course

1) It is not allowed to lock the bus by resetting the EBCMOD0.ARBN bit, as this can lead to bus conflicts.

## External Bus Controller (EBC)

a locked bus master not owning the bus can request the external bus. If a master and a slave are requesting the external bus at the same time for several accesses, they toggle the ownership after each access cycle if the bus is not locked.

### 11.7.5 Direct Master Slave Connection

If one XC27x5X is configured as master and the other as slave and both are working on the same external bus as bus master, they can be connected directly together for bus arbitration as shown in **Figure 11-13**. As both EBCs assume after reset to own the external bus, the ‘slave’ CPU has to be released from reset and initialized first, before starting the ‘master’ CPU. The other way is to start both systems at the same time but then both EBC must be configured from internal memory and the PSW.HLDEN bits set before the first external bus request.



**Figure 11-13 Connecting two XC27x5X using Master/Slave Arbitration**

When multiple (more than two) bus masters (XC27x5X or other masters) shall share the same external resources an additional external bus arbiter logic is required that determines the currently active bus master and that controls the necessary signal sequences.

## 11.8 EBC Idle State

When the external bus interface of EBC is enabled, but no internal or external access is currently executed, the EBC is idle. As long as only on-chip resources such as RAM, peripherals (excluding LXBUS peripherals connected via EBC), registers, etc. are used, the external bus interface does not change (see table 11-2).

The external control signals ( $\overline{RD}$  and  $\overline{WR}$  or  $\overline{WRL}/\overline{WRH}$  if enabled) remain inactive (high) during EBC idle state.

**Table 11-2 Status of the External Bus Outputs During EBC Idle State**

| Pins                                                                    | Status of Pins During EBC Idle                    |
|-------------------------------------------------------------------------|---------------------------------------------------|
| AD15...AD0                                                              | tristate (floating)                               |
| A15...A0                                                                | undefined address (if used for the bus interface) |
| A23...A16                                                               | undefined segment address (on selected pins)      |
| CS7...CS0                                                               | inactive (high)                                   |
| BHE                                                                     | level corresponding to last external access       |
| ALE                                                                     | inactive (low)                                    |
| $\overline{RD}$ , $\overline{WR}$ , $\overline{WRL}$ , $\overline{WRH}$ | inactive (high)                                   |

## 11.9 Register Description

The EBC registers are located in the internal IO area. Registers located there use the shorthand XSFR.

**Table 11-3 Registers Address Space**

| Module | Base Address        | End Address         | Note |
|--------|---------------------|---------------------|------|
| EBC    | 00EE00 <sub>H</sub> | 00EEFF <sub>H</sub> |      |

### 11.9.1 EBC Mode Registers

The two mode registers control the XC27x5X EXTBUS pin usage and configuration. Disabled EXTBUS pins may be usable as general purpose IO as described in the “Parallel Ports” chapter.

#### EBCMOD0

| XSFR(00 <sub>H</sub> ) |         |         |         |        |         |        |        |    |       |    |       | Reset value: 5000 <sub>H</sub> |   |   |   |  |
|------------------------|---------|---------|---------|--------|---------|--------|--------|----|-------|----|-------|--------------------------------|---|---|---|--|
| 15                     | 14      | 13      | 12      | 11     | 10      | 9      | 8      | 7  | 6     | 5  | 4     | 3                              | 2 | 1 | 0 |  |
| RDY POL                | RDY DIS | ALE DIS | BYT DIS | WR CFG | EBC DIS | SLA VE | ARB EN |    | CSPEN |    | SAPEN |                                |   |   |   |  |
| RW                     | RW      | RW      | RW      | RW     | RW      | RW     | RW     | RW | RW    | RW | RW    |                                |   |   |   |  |

| Field               | Bits | Type | Description                                                                                              |
|---------------------|------|------|----------------------------------------------------------------------------------------------------------|
| RDYPOL              | 15   | rw   | <b>READY Pin Polarity</b><br>0 <sub>B</sub> READY is active low<br>1 <sub>B</sub> READY is active high   |
| RDYDIS              | 14   | rw   | <b>READY Pin Disable</b><br>0 <sub>B</sub> READY enabled<br>1 <sub>B</sub> READY disabled                |
| ALEDIS              | 13   | rw   | <b>ALE Pin Disable</b><br>0 <sub>B</sub> ALE enabled<br>1 <sub>B</sub> ALE disabled                      |
| BYTDIS              | 12   | rw   | <b>BHE Pin Disable</b><br>0 <sub>B</sub> BHE enabled<br>1 <sub>B</sub> BHE disabled                      |
| WRCFG <sup>1)</sup> | 11   | rw   | <b>Configuration for Pins WR/WRL, BHE/WRH</b><br>0 <sub>B</sub> WR and BHE<br>1 <sub>B</sub> WRL and WRH |

## External Bus Controller (EBC)

| Field         | Bits  | Type | Description                                                                                                                                                                                                                                                     |
|---------------|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>EBCDIS</b> | 10    | rw   | <b>EBC Pins Disable</b><br>$0_B$ EBC is using the pins for external bus<br>$1_B$ EBC pins disabled                                                                                                                                                              |
| <b>SLAVE</b>  | 9     | rw   | <b>SLAVE Mode Enable</b><br>$0_B$ Bus arbiter acts in master mode<br>$1_B$ Bus arbiter acts in slave mode                                                                                                                                                       |
| <b>ARBEN</b>  | 8     | rw   | <b>BUS Arbitration Pins Enable</b><br>$0_B$ HOLD, HLDA and BREQ pins are disabled<br>$1_B$ pins act as HOLD, HLDA and BREQ                                                                                                                                      |
| <b>CSPEN</b>  | [7:4] | rw   | <b>CSx Pins Enable (only external CSx)</b><br>$0_H$ All external Chip Select pins disabled.<br>$1_H$ CS0 pin enabled<br>$2_H$ CS1 and CS0 pin enabled<br>$\dots$ ...<br>$5_H$ Five CSx pins enabled: CS4-CS0<br>other bit combinations not supported (reserved) |
| <b>SAPEN</b>  | [3:0] | rw   | <b>Segment Address Pins Enable</b><br>$0_H$ All segment address pins disabled<br>$1_H$ One: A[16] enabled<br>$\dots$ ...<br>$8_H$ Eight: A[23:16] enabled<br>other bit combinations not supported (reserved)                                                    |

1) A change of the bit content is not valid before the next external bus access cycle.

### Byte Write Configurations

For 16-bit data bus configurations the byte write characteristics are programmable by bitfield WRCFG. The following table illustrates the related signals function.

**Table 11-4 Byte Write Configurations**

| written byte |       | WRCFG=0  |            |         | WRCFG=1  |          |         |
|--------------|-------|----------|------------|---------|----------|----------|---------|
| low          | high  | WR       | BHE        | ADDR[0] | WRL      | WRH      | ADDR[0] |
| -            | -     | inactive | don't care | 0/1     | inactive | inactive | 0/1     |
| write        | -     | active   | inactive   | 0       | active   | inactive | 0/1     |
| -            | write | active   | active     | 1       | inactive | active   | 0/1     |
| write        | write | active   | active     | 0       | active   | active   | 0/1     |

**EBCMOD1**
**EBC Mode Register 1**
**XSFR(02<sub>H</sub>)**
**Reset value: 003F<sub>H</sub>**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6          | 5          | 4          | 3          | 2 | 1     | 0 |
|----|----|----|----|----|----|---|---|---|------------|------------|------------|------------|---|-------|---|
|    |    |    |    |    |    |   | 0 |   | WRP<br>DIS | DHP<br>DIS | ALP<br>DIS | A0P<br>DIS |   | APDIS |   |

Below the table, there are read (r) and write (rw) access rights indicated under each bit position.

| Field  | Bits   | Type | Description                                                                                                                                                                                                                                                                                                                                                       |
|--------|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | [15:8] | r    | <b>Reserved</b><br>Read as 0, should be written 0                                                                                                                                                                                                                                                                                                                 |
| WRPDIS | 7      | rw   | <b>WR/WRL Pin Disable</b><br>0 <sub>B</sub> WR/WRL pin enabled<br>1 <sub>B</sub> WR/WRL pin disabled                                                                                                                                                                                                                                                              |
| DHPDIS | 6      | rw   | <b>Data High Port Pins Disable</b><br>0 <sub>B</sub> Address/Data bus pins 15-8 enabled<br>1 <sub>B</sub> Address/Data bus pins 15-8 disabled.                                                                                                                                                                                                                    |
| ALPDIS | 5      | rw   | <b>Address Low Pins Disable</b><br>0 <sub>B</sub> Address bus pins 7-0 generally enabled<br>(depending on APDIS/A0PDIS)<br>1 <sub>B</sub> Address bus pins 7-0 disabled.                                                                                                                                                                                          |
| A0PDIS | 4      | rw   | <b>Address Bit 0 Pin Disable</b><br>0 <sub>B</sub> Address bus pin 0 enabled<br>1 <sub>B</sub> Address bus pin 0 disabled.                                                                                                                                                                                                                                        |
| APDIS  | [3:0]  | rw   | <b>Address Port Pins Disable</b><br>0 <sub>H</sub> Address bus pins A15-A1 enabled<br>1 <sub>H</sub> Pin A15 disabled, A14-A1 enabled<br>2 <sub>H</sub> Pins A15-A14 disabled, A13-A1 enabled<br>3 <sub>H</sub> Pins A15-A13 disabled, A12-A1 enabled<br>...<br>E <sub>H</sub> Pins A15-A2 disabled, A1 enabled<br>F <sub>H</sub> Address bus pins 15-1 disabled. |

### 11.9.2 Timing Control Registers

The timing control registers are used to program the cycle timing for the different access phases. The timing control registers may be reprogrammed during code fetches from the affected address window. The new settings become valid for the following access.

## External Bus Controller (EBC)

**TCONCS0**
**Timing Control for CS0**
**XSFR(10<sub>H</sub>)**
**Reset value: 7C3D<sub>H</sub>**
**TCONCSx (x=1-4)**
**Timing Control for CSx**
**XSFR(10<sub>H</sub>+x\*8)**
**Reset value: 0000<sub>H</sub>**

| 15 | 14    | 13    | 12 | 11 | 10  | 9 | 8 | 7 | 6   | 5   | 4   | 3   | 2   | 1 | 0 |
|----|-------|-------|----|----|-----|---|---|---|-----|-----|-----|-----|-----|---|---|
| 0  | WRPHF | RDPHF |    |    | PHE |   |   |   | PHD | PHC | PHB | PHB | PHA |   |   |

r      rw      rw           rw           rw      rw      rw      rw      rw      rw      rw      rw      rw

| Field | Bits    | Type | Description                                                                                         |
|-------|---------|------|-----------------------------------------------------------------------------------------------------|
| 0     | 15      | r    | <b>Reserved</b><br>Read as 0, should be written 0                                                   |
| WRPHF | [14:13] | rw   | <b>Write Phase F</b><br>00 <sub>B</sub> 0 clock cycles<br>... ...<br>11 <sub>B</sub> 3 clock cycles |
| RDPHF | [12:11] | rw   | <b>Read Phase F</b><br>00 <sub>B</sub> 0 clock cycles<br>... ...<br>11 <sub>B</sub> 3 clock cycles  |
| PHE   | [10:6]  | rw   | <b>Phase E</b><br>0 <sub>H</sub> 1 clock cycle<br>... ...<br>1F <sub>H</sub> 32 clock cycles        |
| PHD   | 5       | rw   | <b>Phase D</b><br>0 <sub>B</sub> 0 clock cycles<br>1 <sub>B</sub> 1 clock cycle                     |
| PHC   | [4:3]   | rw   | <b>Phase C</b><br>00 <sub>B</sub> 0 clock cycles<br>... ...<br>11 <sub>B</sub> 3 clock cycles       |
| PHB   | 2       | rw   | <b>Phase B</b><br>0 <sub>B</sub> 1 clock cycle<br>1 <sub>B</sub> 2 clock cycles                     |
| PHA   | [1:0]   | rw   | <b>Phase A</b><br>00 <sub>B</sub> 0 clock cycles<br>... ...<br>11 <sub>B</sub> 3 clock cycles       |

### 11.9.3 Function Control Registers

The Function Control registers are used to control the bus and ready functionality for a selected address window. It can be distinguished between 8 and 16 bit bus and multiplexed and demultiplexed accesses. Furthermore it can be defined whether the address window (and its chip select signal CS<sub>x</sub>) is generally enabled or not.

#### FCONCS0

##### Function Control for CS0

 XSFR(12<sub>H</sub>)

 Reset value: 0011<sub>H</sub>

##### FCONCSx (x = 1-4)

##### Function Control for CSx

 XSFR(12<sub>H</sub>+x\*8)

 Reset value: 0000<sub>H</sub>

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5    | 4 | 3       | 2      | 1     | 0 |
|----|----|----|----|----|----|---|---|---|---|------|---|---------|--------|-------|---|
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | BTYP | 0 | RDY MOD | RDY EN | EN CS |   |

| Field  | Bits   | Type | Description                                                                                                                                                                            |
|--------|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | [15:6] | r    | <b>Reserved</b><br>Read as 0, should be written 0                                                                                                                                      |
| BTYP   | [5:4]  | rw   | <b>Bus Type Selection</b><br>00 <sub>B</sub> 8 bit Demultiplexed<br>01 <sub>B</sub> 8 bit Multiplexed<br>10 <sub>B</sub> 16 bit Demultiplexed<br>11 <sub>B</sub> 16 bit Multiplexed    |
| 0      | 3      | r    | <b>Reserved</b><br>Read as 0, should be written 0                                                                                                                                      |
| RDYMOD | 2      | rw   | <b>Ready Mode</b><br>0 <sub>B</sub> asynchronous READY<br>1 <sub>B</sub> synchronous READY                                                                                             |
| RDYEN  | 1      | rw   | <b>Ready enable</b><br>0 <sub>B</sub> access time is controlled by bitfield PHE <sub>x</sub><br>1 <sub>B</sub> access time is controlled by bitfield PHE <sub>x</sub> and READY signal |
| ENCS   | 0      | rw   | <b>Enable Chip Select</b><br>0 <sub>B</sub> disable<br>1 <sub>B</sub> enable                                                                                                           |

*Note: The specific ENCS<sub>x</sub> bits in the FCONCS<sub>x</sub> registers enable the related address windows and bus functions and the corresponding chip select signal CS<sub>x</sub>. Additionally it depends on the definition of bitfield CSPEN in register EBCMOD0*

## External Bus Controller (EBC)

*how many CS<sub>x</sub> pins are made available for the external system. If an address window is enabled but no external pin is available for the CS<sub>x</sub>, the bus cycle is executed without assertion of the external chip select signal.*

#### 11.9.4 Address Window Selection Registers

**ADDRSEL<sub>x</sub> (x = 1 - 4)**

 Address Range/Size for CS<sub>x</sub>

 XSFR(16<sub>H</sub>+x\*8)

 Reset value: 0000<sub>H</sub>


| Field | Bits   | Type | Description                                                                         |
|-------|--------|------|-------------------------------------------------------------------------------------|
| RGSAD | [15:4] | rw   | <b>Range Start Address</b><br>Address Range Start Address Selection                 |
| RGSZ  | [3:0]  | rw   | <b>Range Size</b><br>Address Range Size Selection (see <a href="#">Table 11-1</a> ) |

## 11.10 EBC Implementation in XC27x5X

The EBC within the XC27x5X automatically affects the behaviour of other device components. In particular with memory mapping and ports allocation the EBC takes a priority role. To understand the particular relations to memory and ports the following chapters are recommended for additional reading:

- Memory Organization
- Parallel Ports

### 11.10.1 Unused Registers

The XC27x5X external chip select signals are limited due to chip packaging. According to this limitation the corresponding EBC channels are not available. The channels x=(5, 6) with related set of registers ADDRSELx, TCONCSx, FCONCSx are therefore not available for use. For software compatibility reasons the corresponding register address space must not be read or written.

### 11.10.2 Access Control to LXBUS Modules

In the XC27x5X the EBC channel 7 is reserved for access to chip internal LXBUS peripherals. In general accesses to LXBUS are not visible on the external bus EXTBUS. During LXBUS cycles the EXTBUS remains enabled but is driven to inactive states (control signals) or switched into the read mode (busses).

### 11.10.3 Shutdown Control

In case of a shutdown request from the SCU the EBC ensures that all the different functions of the EBC are in a non-active state before the whole chip is switched to a power save mode. A running bus cycle is finished, still requested bus cycles are executed. Depending on the master/slave configuration of EBC, the external bus arbiter is controlled for regaining the bus (master) before performing the requested cycles, or the external bus must be released after complete execution of still requested bus cycles. Only when this shutdown sequence is terminated, the shutdown acknowledge is generated from EBC (and from other modules, as described for SCU) and the chip can enter the requested mode.

**Table 11-5** gives an overview of the shutdown control in EBC depending on the EBC configuration.

**Table 11-5 EBC Shutdown Control**

| Arbitration Mode | Master Mode                                                                                  |                                                                                                                  | Slave Mode                                                                      |                                                                                                       |
|------------------|----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| Bus control      | With control of the bus                                                                      | Without control of the bus                                                                                       | With control of the bus                                                         | Without control of the bus                                                                            |
|                  | Finish all pending cycle requests.<br>Send shutdown acknowledge with the control of the bus. | Ask for the bus.<br>Finish all pending cycle requests.<br>Send shutdown acknowledge with the control of the bus. | Finish all pending requests.<br>Send shutdown acknowledge after leaving the bus | Ask for the bus if needed and finish all requests.<br>Send shutdown acknowledge after leaving the bus |

### 11.10.4 Dedicated Registers

The dedicated EBC registers are located in the internal IO area. Registers located there use the shorthand XSFR.

#### 11.10.4.1 Registers dedicated to LXBUS modules

For accesses to MultiCAN and USICs CS7 and its control registers ADDRSEL7, TCONCS7 and FCONCS7 are used. The selection of LXBUS is chip internally controlled with CS7.

#### TCONCS7

The LXBUS cycle timing is controlled with register TCONCS7. It uses the shortest possible timing with two clock cycles for one bus cycle. But this minimum timing will be lengthened with waitstate(s) controlled by the modules using the READY function. This timing is reflected by the reset value of TCONCS7.

#### TCONCS7

| Timing Control for CS7 |       |       |    |    |     |   |   |   |     |     |     |     |   |   | XSFR(48H) |  |  |  |
|------------------------|-------|-------|----|----|-----|---|---|---|-----|-----|-----|-----|---|---|-----------|--|--|--|
| 15                     | 14    | 13    | 12 | 11 | 10  | 9 | 8 | 7 | 6   | 5   | 4   | 3   | 2 | 1 | 0         |  |  |  |
| 0                      | WRPHF | RDPHF |    |    | PHE |   |   |   | PHD | PHC | PHB | PHA |   |   |           |  |  |  |
| r                      | r     | r     |    |    | r   |   |   |   | r   | r   | r   | r   |   |   |           |  |  |  |

| Field        | Bits    | Type | Description                                                                       |
|--------------|---------|------|-----------------------------------------------------------------------------------|
| <b>0</b>     | 15      | r    | <b>Reserved</b><br>Read as 0, should be written 0                                 |
| <b>WRPHF</b> | [14:13] | rw   | <b>Write Phase F</b><br>$00_B$ 0 clock cycles<br>... ...<br>$11_B$ 3 clock cycles |
| <b>RDPHF</b> | [12:11] | rw   | <b>Read Phase F</b><br>$00_B$ 0 clock cycles<br>... ...<br>$11_B$ 3 clock cycles  |
| <b>PHE</b>   | [10:6]  | rw   | <b>Phase E</b><br>$0_H$ 1 clock cycle<br>... ...<br>$1F_H$ 32 clock cycles        |
| <b>PHD</b>   | 5       | rw   | <b>Phase D</b><br>$0_B$ 0 clock cycles<br>$1_B$ 1 clock cycle                     |
| <b>PHC</b>   | [4:3]   | rw   | <b>Phase C</b><br>$00_B$ 0 clock cycles<br>... ...<br>$11_B$ 3 clock cycles       |
| <b>PHB</b>   | 2       | rw   | <b>Phase B</b><br>$0_B$ 1 clock cycle<br>$1_B$ 2 clock cycles                     |
| <b>PHA</b>   | [1:0]   | rw   | <b>Phase A</b><br>$00_B$ 0 clock cycles<br>... ...<br>$11_B$ 3 clock cycles       |

### FCONCS7

The value of this dedicated bus function control register is selected according to the requirements of the internally attached modules: 16-bit demultiplexed bus, access time controlled with synchronous READY.

**FCONCS7**
**Function Control for CS7**
**XSFR(4A<sub>H</sub>)**
**Reset value: 0027<sub>H</sub>**

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5    | 4 | 3       | 2      | 1     | 0 |
|----|----|----|----|----|----|---|---|---|---|------|---|---------|--------|-------|---|
| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | BTYP | 0 | RDY MOD | RDY EN | EN CS | r |

| Field  | Bits   | Type | Description                                                                                                                                                                         |
|--------|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | [15:6] | r    | <b>Reserved</b><br>Read as 0, should be written 0                                                                                                                                   |
| BTYP   | [5:4]  | rw   | <b>Bus Type Selection</b><br>00 <sub>B</sub> 8 bit Demultiplexed<br>01 <sub>B</sub> 8 bit Multiplexed<br>10 <sub>B</sub> 16 bit Demultiplexed<br>11 <sub>B</sub> 16 bit Multiplexed |
| 0      | 3      | r    | <b>Reserved</b><br>Read as 0, should be written 0                                                                                                                                   |
| RDYMOD | 2      | rw   | <b>Ready Mode</b><br>0 <sub>B</sub> asynchronous READY<br>1 <sub>B</sub> synchronous READY                                                                                          |
| RDYEN  | 1      | rw   | <b>Ready enable</b><br>0 <sub>B</sub> access time is controlled by bitfield PHEX<br>1 <sub>B</sub> access time is controlled by bitfield PHEX and READY signal                      |
| ENCS   | 0      | rw   | <b>Enable Chip Select</b><br>0 <sub>B</sub> disable<br>1 <sub>B</sub> enable                                                                                                        |

**Register ADDRSEL7**

The value of the dedicated address select register allocates the address range 20'0000<sub>H</sub> to 20'FFFF<sub>H</sub> in the external IO area for the attached chip internal modules.

**ADDRSEL7**

Address Range/Size for CS7

**XSFR(4E<sub>H</sub>)**

 Reset value: 2004<sub>H</sub>


| Field | Bits   | Type | Description                                                                         |
|-------|--------|------|-------------------------------------------------------------------------------------|
| RGSAD | [15:4] | rw   | <b>Range Start Address</b><br>Address Range Start Address Selection                 |
| RGSZ  | [3:0]  | rw   | <b>Range Size</b><br>Address Range Size Selection (see <a href="#">Table 11-1</a> ) |

## Startup Configuration and Bootstrap Loading

# 12 Startup Configuration and Bootstrap Loading

After startup, the XC27x5X executes code out of an on-chip or off-chip program memory. The initial code source can be selected (refer to the next [Chapter 12.1](#) and [Chapter 12.3](#) to find out how) between the following options:

- **Internal Start** Mode: executes code out of the on-chip program Flash.
- **External Start** Mode: executes code out of an off-chip memory connected to the External Bus Interface.
- **Bootstrap Loading** Modes: execute code out of the on-chip program SRAM (PSRAM). This code is downloaded beforehand via a selectable serial interface.

## 12.1 Startup Mode Selection

After any startup the currently valid startup configuration is indicated in bitfield HWCFG of register SCU\_STSTAT. The startup configurations and modes supported in XC27x5X are described in [Chapter 12.3](#).

A startup configuration can be selected basically in two ways:

1. Via an externally applied hardware configuration upon a Power-on reset  
The hardware configuration is applied to the dedicated TRST-pin and to Port 10 pins (P10[6:0]).  
The hardware that activates a startup configuration during reset may be simple pull resistors for systems that use this feature upon every reset. You may want to use a switchable solution (via jumpers or an external signal) for systems that only temporarily use a hardware configuration.
2. By executing the following software sequence (using SCU\_SWRSTCON and SCU\_RSTCON1 registers):
  - a) Write respective configuration value (refer to [Table 12-2](#) and [Table 12-3](#)) to bitfield SCU\_SWRSTCON.SWCFG;
  - b) Assign desired type of reset to the software request trigger by writing into SCU\_RSTCON1.SW bitfield (by default SCU\_RSTCON1.SW=00<sub>B</sub> meaning no reset generated by software request trigger)
  - c) Set Software Boot Configuration bit: SCU\_SWRSTCON.SWBOOT = 1;
  - d) Trigger a software reset by activating Software Reset Request: SCU\_SWRSTCON.SWRSTREQ = 1.

Additionally, several specific cases of startup configuration handling must be noted:

1. Application reset triggered by hardware request (for example WDT, ESRx) - TRST and P10 pins are not evaluated but the same startup configuration is used as after the previous reset;
2. Application or Internal Application reset triggered by software (with setting SCU\_SWRSTCON.SWRSTREQ=1) - can have different consequences:

## Startup Configuration and Bootstrap Loading

- a) if Software Boot Configuration is selected (SCU\_SWRSTCON.SWBOOT=1) - the startup configuration (SCU\_STSTAT.HWCFG) is updated from SCU\_SWRSTCON.SWCFG bitfield;
  - b) otherwise - the same startup configuration is used as after the previous reset.
3. Internal Application reset triggered by hardware request - only TRST pin is evaluated (refer to [Page 12-7](#)):
- a) if TRST=0 - Internal Start from Flash is selected, no debugging is possible;
  - b) otherwise - the same startup configuration is used as after the previous reset.

## 12.2 Device Status after Startup

The main parameters of XC27x5X-status at the point of time when the first user instruction is executed are summarized below.

### 12.2.1 Registers modified by the Startup Procedure

**Table 12-1** shows the XC27x5X registers which are initialized during the startup procedure with values different from their reset-content (defined into respective register-descriptions).

There are two groups of registers regarding the way they are affected by startup procedure:

1. registers initialized after any startup;
2. registers initialized after startup triggered by a power-on in DMP\_1 power domain;

*Note: Power-on in DMP\_M domain means power-on event also in DMP\_1.*

The registers in **Table 12-1** are grouped in accordance to the above differentiation.

Two additional points regarding register-content after startup must be taken into account:

- The register-modifications shown in **Table 12-1** happen independently on the startup mode currently selected, which means also in **Internal Start** mode.  
Next to these, in other modes - **External Start** and **Bootstrap Loading** ([Chapter 12.5](#), [Chapter 12.6](#)) - more registers are additionally modified during startup, as described into respective Specific Settings chapters for any of the modes.
- The values seen in some bits after startup can be affected not only by the reset procedure itself but also by other events during and even before the last startup - for example an Emergency Event can change the clock-system status.

Therefore occasional exceptions are possible from the above values (as well as from the default register content after reset), mainly for some clock control/status flags. For more information on such special cases and their handling - refer to XC27x5X Programmer's Guide.

## Startup Configuration and Bootstrap Loading

**Table 12-1 XC27x5X Registers installed by the Startup Procedure**

| Register                    | Value                      | Comments                                                          |
|-----------------------------|----------------------------|-------------------------------------------------------------------|
| 1. After any startup:       |                            |                                                                   |
| TRAPDIS                     | 019F <sub>H</sub>          | All SCU-controlled traps disabled except PET and RAT              |
| RSTCON1                     | UU:<br>10uu:U <sub>H</sub> | Internal Application Reset request generated by WDT               |
| IMBCTRL                     | 558C <sub>H</sub>          | In External or Bootstrap Loader mode with protected Flash         |
|                             | A58C <sub>H</sub>          | In Internal Start mode or Flash not protected                     |
| R8..R15                     | XXXX                       | GPRs from Local Bank 1 - used by startup procedure                |
| 2. After power-on in DMP_1: |                            |                                                                   |
| PLLCOM0                     | 0F00 <sub>H</sub>          | PLL in Normal Mode, N-divider = 16                                |
| PLLCOM3                     | 0007 <sub>H</sub>          | K2-divider = 8                                                    |
| SYSCON0                     | 0002 <sub>H</sub>          | The PLL output ( $f_{PLL}$ ) used as system clock                 |
| WUOSCCON                    | 0000 <sub>H</sub>          | Wake up Oscillator enabled with $f_{WU}$ approx. 500kHz           |
| HPOSCCON                    | U:u0uu:<br>UU <sub>H</sub> | PLLSTAT.FINDIS bit will not be set<br>in an OSCWDT emergency case |
| PLLOSCCON                   | XXXX <sub>H</sub>          | Device-specific value (chip-to-chip trimming)                     |
| EVRMCON0                    | 0100 <sub>H</sub>          | EVR_M Control 0 register                                          |
| EVR1CON0                    | 0D00 <sub>H</sub>          | EVR_1 Control 0 register                                          |
| EVR1SET15VHP                | 401B <sub>H</sub>          | EVR_1 Setting for 1.5V HP register                                |
| EVR1SET10V                  | 405B <sub>H</sub>          | EVR_1 Setting for 1.0V register                                   |
| EVR1SET15VLP                | 40DB <sub>H</sub>          | EVR_1 Setting for 1.5V LP register                                |
| PVCMCON0                    | 2544 <sub>H</sub>          | PVC_M Control for Step 0 register                                 |
| PVC1CON0                    | 2544 <sub>H</sub>          | PVC_1 Control for Step 0 register                                 |

### 12.2.2 System Frequency after Startup

The system clock which is active when the first user instruction is executed, depends on the currently selected startup mode and the last startup trigger:

- after power-on in all modes except CAN Bootstrap Loader ([Chapter 12.6.4](#)) - 10MHz (nominal value) from the XC27x5X internal oscillator (doubled frequency);
- after power-on in CAN Bootstrap Loader ([Chapter 12.6.4](#)) - the frequency of an external crystal connected to XTAL-pins, 4MHz minimum;

## Startup Configuration and Bootstrap Loading

- after any functional (not power-on) reset - the clock system configuration is not changed by device startup, respectively the system frequency remains as before the reset.

### 12.2.3 Watchdog Timer handling

The Watchdog Timer (WDT) in XC27x5X is always enabled by the startup procedure and configured to generate Internal Application Reset.

Therefore, the user software must:

- if WDT-usage is foreseen by the code - service it for a first time within approx. 65500 system clock cycles after startup;
- otherwise - disable it within the same time frame as above but before to execute End of Init (EINIT).

The reset requested by WDT serves as response to a device malfunction, due to which malfunction user software can not be anymore executed correctly - respectively the WDT is not regularly served. This reset causes a new device startup followed by user software restart.

The Internal Application Reset - default for WDT - affects not all the modules in XC27x5X - refer to "Module Reset Behavior" in SCU Chapter. The unaffected modules do not change their state, so if this state is "wrong" it will not be recovered to "correct" due to Internal Application Reset, also when triggered by WDT. Therefore, the default WDT configuration and usage can resolve well purely software malfunction but not other failures - for example in clock- or power- system.

One reset-request which puts all the XC27x5X modules into a known - and correctly functioning - initial state is from PORST-pin. Therefore, if an application requires that correct device restart upon WDT reset is guaranteed, the implementation must be done according to the next [Chapter 12.2.3.1](#).

#### 12.2.3.1 Triggering Power-on Reset by WDT

This feature requires that either ESR1 or ESR2 pin is dedicated to it, e.g. not available for another functionality.

The following must be done by the user to have power-on reset triggered by WDT:

- in hardware: tie the selected ESRx ( $x=1,2$ ) pin to PORST pin of the device;
- in software: at its very beginning, install  $1110_B$  into bits[3:0] of the respective ESRCFG $x$  register ( $x=1,2$ ).

*Note: Keep the WDT reset configuration as installed by startup procedure - Internal Application Reset.*

With the above preparation, any Internal Application Reset - including triggered by WDT - will drive the selected ESR $x$  pin low so leading to power-on and a next device restart.

## Startup Configuration and Bootstrap Loading

**Attention:** When using this solution, Internal Application reset is no more available as separate reset type.

Respectively upon this reset all the device resources will be initialized as upon power-on and any previous information will be lost.

Therefore, when controlling this feature by WDT do not assign Internal Application Reset to any other trigger if prevention of previous information/status is needed.

For additional information on this feature - refer to Application Note AP16146 .

### 12.2.4 Startup Error state

To prevent possible negative consequences for the device and/or the system, upon unrecoverable error during startup XC27x5X is put onto a stable, passive and neutral to the external world state - power-save mode with DMP\_1 shut down and DMP\_M powered with 1V.

This state can be exited with power-on reset only.

## Startup Configuration and Bootstrap Loading

### 12.3 Supported Startup Modes and Options

XC27x5X supports variety of startup modes, allowing the user to make selections in three aspects:

- main functionality - where from the user code will be started (on-chip Flash, PSRAM, external memory);
- optionally - a way for initial code-downloading into PSRAM before to start it:
  - from an external host via a communication interface - UART, CAN, SSC;
  - from Stand-by RAM (SBRAM) - after exiting a power-saving mode;
- debug-related - either debugging will be possible, and if Yes - which debug-interface to use (JTAG, DAP, selectable pin-assignments).

Following from the above differentiation, the startup modes in XC27x5X are divided into several groups, described in [Chapter 12.3.1](#), [Chapter 12.3.2](#) and [Chapter 12.3.3](#).

## Startup Configuration and Bootstrap Loading

### 12.3.1 Basic Startup Modes

These modes (refer to [Table 12-2](#)) have no debug support and no special features.

**Table 12-2 Basic XC27x5X Startup Modes**

| Startup Mode                               | STSTAT.HWCFG<br>Value <sup>1)</sup> | Configuration pins <sup>2)</sup> |             |   |   |   |   |   |   |   |   |
|--------------------------------------------|-------------------------------------|----------------------------------|-------------|---|---|---|---|---|---|---|---|
|                                            |                                     | TRST                             | P10 [6 : 0] |   |   |   |   |   |   |   |   |
| Internal Start from Flash                  | 00 <sub>H</sub>                     | 0                                | x           | x | x | x | x | x | x | x | x |
| UART Bootloader 2.x <sup>3)</sup>          | 02 <sub>H</sub>                     | 1                                | x           | x | x | x | 0 | 1 | 0 | 0 | 0 |
| UART Bootloader 7.x <sup>4)</sup>          | 06 <sub>H</sub>                     | 1                                | x           | x | x | x | 1 | 1 | 1 | 0 | 0 |
| SSC Bootloader                             | 09 <sub>H</sub>                     | 1                                | x           | x | x | 1 | 0 | 0 | 0 | 1 | 0 |
| CAN Bootloader                             | 0D <sub>H</sub>                     | 1                                | x           | x | x | 1 | 1 | 0 | 0 | 1 | 0 |
| UART Enhanced Bootloader 2.x <sup>3)</sup> | 10 <sub>H</sub>                     | 1                                | 0           | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
| External Start <sup>5)</sup>               | 70 <sub>H</sub>                     | 1                                | 1           | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |

1) Bitfield HWCFG can be loaded from Port 10 or from bitfield SWCFG in register SWRSTCON.

2) x means that the level on the corresponding pin is irrelevant.

3) 2.x means: TxD (transmit data) at P2.3 pin, RxD (receive data) at P2.4 pin.

4) 7.x means: TxD (transmit data) at P7.3 pin, RxD (receive data) at P7.4 pin. **Not available in 64-pin package.**

5) Not available in 64-pin package.

The XC27x5X functionality in different modes - Internal start, External start, Bootstrap loading - is described further in [Chapter 12.4](#), [Chapter 12.5](#), [Chapter 12.6](#) respectively.

### 0-pin Configuration

This is a new feature for XC27x5X, meaning usage of no General-purpose Input-output (GPIO) pins - including no assignment of any alternate function to a pin - to select the startup configuration which is supposed to be the most used one - Internal Start from Flash.

One dedicated pin - TRST - is used as a checkpoint, as follows:

- TRST=0 during reset - no other pins (also from Port 10) are evaluated, the user code is started from Internal Flash memory - refer to the first row in [Table 12-2](#);
- TRST=1 during reset - some of the Port 10 pins are evaluated to determine the further device-functioning. The number of P10 pins used for that purpose varies from 3 up to 7- refer to [Table 12-2](#) and [Table 12-3](#).

## Startup Configuration and Bootstrap Loading

### 12.3.2 Startup Modes with Debug Support

These startup selections (refer to **Table 12-3**) lead to user-code start either from Internal Flash or from External memory. So from functional point of view they are similar to two from the **Basic Startup Modes** in **Table 12-2**, but additionally these selections allow an external tool (debugger) to be connected and used during the development process.

**Table 12-3 XC27x5X Startup Mode Configurations with debug support**

| Startup Mode                 | Debug Interface          | STSTAT.HWCFG Value <sup>1)</sup> | CFG pins P10 [6:0] <sup>2)</sup><br>TRST=1 |   |   |   |   |   |   |   |
|------------------------------|--------------------------|----------------------------------|--------------------------------------------|---|---|---|---|---|---|---|
| Internal Start from Flash    | JTAG pos.B               | 03 <sub>H</sub>                  | x                                          | x | x | x | 0 | 1 | 1 | 1 |
|                              | DAP pos.1                | 04 <sub>H</sub>                  | x                                          | x | x | x | 1 | 0 | 0 | 0 |
|                              | from Flash <sup>3)</sup> | 07 <sub>H</sub>                  | x                                          | x | x | x | 1 | 1 | 1 | 1 |
|                              | DAP pos.0                | 01 <sub>H</sub>                  | x                                          | x | x | 0 | 0 | 0 | 0 | 1 |
|                              | DAP pos.2 <sup>4)</sup>  | 05 <sub>H</sub>                  | x                                          | x | x | 0 | 1 | 0 | 1 | 1 |
|                              | JTAG pos.C <sup>4)</sup> | 40 <sub>H</sub>                  | 1                                          | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|                              | JTAG pos.D <sup>5)</sup> | 50 <sub>H</sub>                  | 1                                          | 0 | 1 | 0 | 0 | 0 | 0 | 0 |
| External Start <sup>4)</sup> | from Flash <sup>3)</sup> | 60 <sub>H</sub>                  | 1                                          | 1 | 0 | 0 | 0 | 0 | 0 | 0 |

1) Bitfield HWCFG can be loaded from Port 10 or from bitfield SWCFG in register SWRSTCON.

2) x means that the level on the corresponding pin is irrelevant.

3) A defined location in Flash (C0'01F0<sub>H</sub>) must contain a value (2 Bytes) for DBGPRR register and the next word-location (C0'01F2<sub>H</sub>) must contain the inverse value.

From the 16-bit value in Flash the four most-significant bits are don't care - they are handled by the startup procedure itself.

If the inverse-condition does not match - the value is considered as invalid and JTAG pins at position A are configured by default.

4) Not available in 64-pin package.

5) Not available in 64 and 100-pin package.

The variety of startup configurations (**Table 12-3**) in this case serve to select the type (DAP or JTAG) and pin-location of the debug interface which will be enabled. Besides of this selection - done either via P10-pins or by SWRSTCON.HWCFG-bitfield - two basic conditions exist for debug-interface handling:

- debug interface configuration is a part of the complete device startup configuration. Therefore debug interface enabling/disabling/(re)configuration takes place only when the startup configuration (e.g. the startup mode selection) is updated in some of the ways described in **Chapter 12.1**.

For example, upon an application reset triggered by hardware source (let say WDT) the debug interface will not be touched.

- debug interface will be always disabled, if Internal Start is selected and the on-chip Flash is protected

## Startup Configuration and Bootstrap Loading

The exact meaning - interface types and pin-assignments - of different debug interface selections is shown in **Table 12-4**. The last column of this table shows the value, which must be written into Flash location C0 01F0<sub>H</sub>, if Debug Interface Configuration from Flash has been selected as startup option (refer to **Table 12-3**).

**Table 12-4 Debug-selections in XC27x5X: interface types and pin assignments**

| Debug Interface |                     | Pins used for Debugging:       |                     | DBGPRR value in Flash addr.<br>C0 01F0 <sub>H</sub> |
|-----------------|---------------------|--------------------------------|---------------------|-----------------------------------------------------|
| Type            | Position            | main interface<br>(obligatory) | BRKIN<br>(optional) |                                                     |
| DAP             | pos.0               | P2.9, P7.0                     | P5.10               | 1000 <sub>H</sub>                                   |
|                 | pos.1               | P10.9, P10.12                  | P10.8               | 1155 <sub>H</sub>                                   |
|                 | pos.2 <sup>1)</sup> | P7.0, P7.4                     | P7.1                | 12AA <sub>H</sub>                                   |
| JTAG            | pos.A               | P2.9, P5.2, P5.4, P7.0         | P5.10               | 1800 <sub>H</sub>                                   |
|                 | pos.B               | P10.9, P10.10, P10.11, P10.12  | P10.8               | 1955 <sub>H</sub>                                   |
|                 | pos.C <sup>1)</sup> | P7.0, P7.2, P7.3, P7.4         | P7.1                | 1AAA <sub>H</sub>                                   |
|                 | pos.D <sup>2)</sup> | P8.3, P8.4, P8.5, P10.12       | P8.6                | 1BFF <sub>H</sub>                                   |
| not available   | ---                 | ---                            | ---                 | 0000 <sub>H</sub>                                   |

1) Not available in 64-pin package.

2) Not available in 64- and 100-pin packages.

There are two types of interface signals/pins related to debugging:

### Main Debug Interface

These are 2 (in case of DAP) or 4 (in case of JTAG) pins listed in the third column of **Table 12-4**.

If debugging is enabled, these pins are always assigned to the debug-interface, therefore the application software must never use any of them.

### Optional Break Interface

The Break Interface of XC27x5X Debug System includes two signals: BRKIN and BRKOUT.

The usage of this interface is optional, also selectively either only one out of the two signals or both of them can be utilized.

The Break Interface usage requires additional preparation which will be done - when requested - by the external debugger once the main interface is available.

## Startup Configuration and Bootstrap Loading

As long as this preparation and the activation of “Break-In”/“Break-Out” feature has not happened, the respective pin(s) selected to host (potentially) BRKIN/BRKOUT-signal(s) can be still used for other functionality by the application software.

The two Break-signals/pins are handled some differently to each other:

- BRKIN - the exact pin which will be used (in case) for this purpose is determined uniquely by the startup selection - refer to the BRKIN-column in [Table 12-4](#).
- BRKOUT - no pin-selection for this signal is done during startup.  
Few pins are potentially available for BRKOUT-selection - done by the external tool before to activate the “Break-Out” feature:
  - P6.0;
  - P1.5 - not available in 64-pin package;
  - P9.3 - not available in 64- and 100-pin packages;
  - P10.11 - can not be used, if JTAG interface at position B is selected.

## Startup Configuration and Bootstrap Loading

### 12.3.3 Special Startup Features

XC27x5X supports some special features, which allow the user software to influence the device startup, providing additional functionality next to the above (in [Chapter 12.3.1](#) and [Chapter 12.3.2](#)) described.

**Attention:** *The correct usage of these features requires good and detailed understanding of the XC27x5X structure, behavior and programming.*

*The special startup features are dedicated to advanced users, being familiar with device as a whole and especially with the System Control Unit - both as hardware (described in SCU Chapter of this User Manual) and how to control it properly by software (described in the XC27x5X Programmer's Guide).*

#### 12.3.3.1 Supplementary Startup Information from/to the User

The special startup features require/provide additional information from/to the application software, using a dedicated register inside the System Control Unit - STMEM0.

##### STMEM0 Register

The SCU\_STMEM0 register is located in DMP\_M power-supply domain and is Security-protected.

The following startup information can be exchanged with application software using this register:

1. the user software can influence the next device startup by writing into STMEM0 bits[15:6]  
The supported features are described in [Chapter 12.3.3.2](#).
2. if STMEM0[4]=0 after startup - this startup has been triggered by a Functional (i.e. Application or Internal Application) Reset;  
In such a case the emergency-status flags indicated in SCU\_SYSCON0 bits[15:12] upon device startup can be read by user software from SCU\_STMEM0 bits[3:0]
3. if STMEM0[4]=1 after startup - this startup has been triggered by a Power-On;  
In such a case, additional information is provided by SCU\_STMEM0[3] bit:
  - a) STMEM0[3]=0 - Power-On in DMP\_1 domain only
  - b) STMEM0[3]=1 - Power-On in both DMP\_1 and DMP\_M domains

## Startup Configuration and Bootstrap Loading

**STMEM0**
**Startup Memory 0 Register**
**ESFR (F0A0<sub>H</sub>/50<sub>H</sub>)**
**Reset Value: 0000<sub>H</sub>**

| 15    | 14 | 13    | 12    | 11    | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|-------|----|-------|-------|-------|----|---|---|---|---|---|---|---|---|---|--------|
| USSET | 0  | RINDP | RINDS | RINPS | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | STSIND |

| Field  | Bits     | Typ | Description                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| STSIND | [4:0]    | rw  | <b>Startup Status Indication to the user:</b><br>0SPVW Functional reset - bits[3:0] show status flags:<br>S - Clock Select status <sup>1)</sup><br>P - PVC1 Emergency Event Source status <sup>1)</sup><br>V - VCOLCK Emergency Event Source status <sup>1)</sup><br>W - OSCWDT Emergency Event Source status <sup>1)</sup><br>10000 Power-on in DMP_1 domain only<br>11000 Power-on in DMP_M and DMP_1 domains<br>else Reserved |
| 0      | 5        | rw  | <b>Reserved</b> , must be written with reset value 0                                                                                                                                                                                                                                                                                                                                                                             |
| 0      | 6,[10:7] | rw  | <b>Reserved</b> , must be written with reset value 0                                                                                                                                                                                                                                                                                                                                                                             |
| RINPS  | 11       | rw  | <b>Initialization of the PSRAM:</b><br>0 not requested<br>1 will be performed upon startup                                                                                                                                                                                                                                                                                                                                       |
| RINDS  | 12       | rw  | <b>Initialization of the DSRAM:</b><br>0 not requested<br>1 will be performed upon startup                                                                                                                                                                                                                                                                                                                                       |
| RINDP  | 13       | rw  | <b>Initialization of the DPRAM:</b><br>0 not requested<br>1 will be performed upon startup                                                                                                                                                                                                                                                                                                                                       |
| 0      | 14       | rw  | <b>Reserved</b> , must be written with reset value 0                                                                                                                                                                                                                                                                                                                                                                             |
| USSET  | 15       | rw  | <b>RAM Initialization upon startup:</b><br>0 not requested<br>1 requested in STMEM0 [13:11]                                                                                                                                                                                                                                                                                                                                      |

1) Bit copied from SYSCON0 register upon startup.

## Startup Configuration and Bootstrap Loading

### 12.3.3.2 Preparing to activate Memory Content Protection

XC27x5X supports two mechanisms for Memory Content protection: ECC (Error Correction Code) and Parity, both are disabled by default.

Any of these mechanisms can be only activated by the user, using the sequence shown at [Figure 12-1](#). The processing according to this sequence includes:

- upon power-on of the device (indicated by **STMEMO[4]=1**, **STMEMO[15]** will be 0 in this case ) - RAM initialization is needed:
  - optionally - if the application will run with system clock faster than 10MHz (system frequency after power-on) - the clock reconfiguration can be done still here to use increased speed for a faster RAM initialization;
  - if parity will be used for some memory - write 1 into the respective bit(s) of SCU\_MCHKCON register (by default ECC is the selected protection type);
  - install request for RAMs initialization by setting **STMEMO[15:11]=10111<sub>B</sub>**; It is also possible to set selectively only some of the bits[13:11] corresponding to the memories in which the Content Protection will be activated (refer to **STMEMO**-description and [Figure 12-1](#)). This will not bring too much - in sense of a faster startup - because all the memories are initialized in parallel and the time-variation if processing one only or all the RAMs will be not so big.
  - trigger an application reset to cause a new device startup  
During this new device startup the RAMs are initialized as requested in **STMEMO[13:11]**.
- if **STMEMO[15]=1** after startup - meaning RAMs have been just initialized:
  - RAM-initialization request is cleared - **STMEMO[15:11]=00000<sub>B</sub>**;
  - ECC/parity is configured/enabled as required by the application
  - continue with further system initialization (if any) and starting the application
- if **STMEMO[15]=0** after functional reset (not power-on) - RAM initialization is not needed and the request is not active:
  - ECC/parity is configured/enabled as required by the application - this is needed because some control registers are reset upon any startup;
  - continue with further system initialization (if any) and starting the application.

The read-operations from initialized memories produce no errors, the data delivered is:

- if ECC is active - 0600<sub>H</sub>;
- if parity is active - 3000<sub>H</sub>.

## Startup Configuration and Bootstrap Loading



Figure 12-1 Software sequence to prepare ECC/Parity usage

## Startup Configuration and Bootstrap Loading

### 12.4 Internal Start

When internal start mode is configured, the XC27x5X immediately begins executing code out of the on-chip Flash memory (first instruction from location C0'0000<sub>H</sub>).

Because internal start mode without debug-support is expected to be the configuration used in most cases, this mode can be selected by pulling low the dedicated (e.g. not available for application-purposes) TRST-pin only - so-called **0-pin Configuration**.

If debug-support is needed - additional configuration options are available, refer to [Chapter 12.3.2](#).

*Note: A read-protected Flash is readable for applications started in Internal mode without disabling the protection.*

### 12.5 External Start

When external start mode is configured, the XC27x5X begins executing code out of an off-chip memory (first instruction from location 00'0000<sub>H</sub>), connected to the XC27x5X's external bus interface.

**Attention: External Startup mode is not supported in 64-pin package devices.**

The External Bus Controller is adjusted to the employed external memory by evaluating additional configuration pins.

Seven pins of P10 are used to select the EBC mode (P10.[10:8]), the address width (P10.[12:11]), and the number of chip select lines (P10.[14:13]). The following tables summarize the available options.

## Startup Configuration and Bootstrap Loading

**Table 12-5 EBC Configuration: EBC Mode**

| EBC Startup Mode                    | Cfg. Pins<br>P10[10:8] |   |   | Pins Used by the EBC                                                         |
|-------------------------------------|------------------------|---|---|------------------------------------------------------------------------------|
| 8-Bit Data, Multiplexed             | 0                      | 0 | 0 | P2.0 ... P2.2, P10.0 ... P10.15                                              |
| 8-Bit Data, Demultiplexed           | 0                      | 0 | 1 | P0.0 ... P0.7, P1.0 ... P1.7, P2.0 ... P2.2, P10.0 ... P10.7, P10.13, P10.14 |
| 16-Bit Data, MUX, <u>BHE</u> mode   | 0                      | 1 | 0 | P2.0 ... P2.2, P2.11, P10.0 ... P10.15                                       |
| 16-Bit Data, MUX, <u>WRH</u> mode   | 0                      | 1 | 1 | P2.0 ... P2.2, P2.11, P10.0 ... P10.15                                       |
| 16-Bit Data, DeMUX,<br>BHE mode, A0 | 1                      | 0 | 0 | P0.0 ... P0.7, P1.0 ... P1.7, P2.0 ... P2.2, P2.11, P10.0 ... P10.14         |
| 16-Bit Data, DeMUX,<br>WRH mode, A0 | 1                      | 0 | 1 | P0.0 ... P0.7, P1.0 ... P1.7, P2.0 ... P2.2, P2.11, P10.0 ... P10.14         |
| 16-Bit Data, DeMUX,<br>BHE mode, A1 | 1                      | 1 | 0 | P2.0 ... P2.2,<br>P10.0 ... P10.15                                           |
| 16-Bit Data, DeMUX,<br>WRH mode, A1 | 1                      | 1 | 1 | P0.0 ... P0.7, P1.0 ... P1.7, P2.0 ... P2.2, P10.0 ... P10.7, P10.13, P10.14 |

**Table 12-6 EBC Configuration: Address Width**

| Available Address Lines | Cfg. Pins<br>P10[12:11] |   | Additional Address Pins |
|-------------------------|-------------------------|---|-------------------------|
| A15 ... A0              | 0                       | 0 | None                    |
| A17 ... A0              | 0                       | 1 | P2.3, P2.4              |
| A19 ... A0              | 1                       | 0 | P2.3 ... P2.6           |
| A23 ... A0              | 1                       | 1 | P2.3 ... P2.10          |

**Table 12-7 EBC Configuration: Chip Select Lines**

| Available Chip Select Lines | Cfg. Pins<br>P10[14:13] |   | Used Pins     |
|-----------------------------|-------------------------|---|---------------|
| CS0 ... CS4                 | 0                       | 0 | P4.0 ... P4.4 |
| CS0                         | 0                       | 1 | P4.0          |
| CS0 ... CS1                 | 1                       | 0 | P4.0, P4.1    |
| None                        | 1                       | 1 | None          |

## Startup Configuration and Bootstrap Loading

### 12.5.1 Specific Settings

When the XC27x5X has entered External Start mode, the configuration is automatically set according to [Table 12-8](#) and [Table 12-9](#).

Note, that the startup procedure does not configure any address window within ADDRSELx registers. Therefore, even if some CS signal is configured (refer to [Table 12-7](#)), the startup procedure only makes the proper settings to assure the adequate pin-functionality in regard to the selected EBC mode. The user software must take care:

- to configure the address window (in ADDRSELx register) for the  $\overline{CSx}$  pin(s) which will be used;
- to enable those pins by setting FCONCSx.ENCS.

**Table 12-8 External start mode-Specific State in EBC Registers**

| Configuration at P10[10:8] | EBCMOD0 [15:8]  | EBCMOD1           | FCONCSx <sup>1)</sup> | Comment (EBC Mode)                  |
|----------------------------|-----------------|-------------------|-----------------------|-------------------------------------|
| 000 <sub>B</sub>           | 30 <sub>H</sub> | 001F <sub>H</sub> | 0011 <sub>H</sub>     | 8-Bit Multiplexed                   |
| 001 <sub>B</sub>           | 70 <sub>H</sub> | 0020 <sub>H</sub> | 0001 <sub>H</sub>     | 8-Bit Demultiplexed                 |
| 010 <sub>B</sub>           | 40 <sub>H</sub> | 0000 <sub>H</sub> | 0031 <sub>H</sub>     | 16-Bit MUX, $\overline{BHE}$        |
| 011 <sub>B</sub>           | 48 <sub>H</sub> | 0000 <sub>H</sub> | 0031 <sub>H</sub>     | 16-Bit MUX, $\overline{WRH}$        |
| 100 <sub>B</sub>           | 60 <sub>H</sub> | 0000 <sub>H</sub> | 0021 <sub>H</sub>     | 16-Bit DeMUX, $\overline{BHE}$ , A0 |
| 101 <sub>B</sub>           | 61 <sub>H</sub> | 0000 <sub>H</sub> | 0021 <sub>H</sub>     | 16-Bit DeMUX, $\overline{WRH}$ , A0 |
| 110 <sub>B</sub>           | 60 <sub>H</sub> | 0010 <sub>H</sub> | 0021 <sub>H</sub>     | 16-Bit DeMUX, $\overline{BHE}$ , A1 |
| 111 <sub>B</sub>           | 61 <sub>H</sub> | 0010 <sub>H</sub> | 0021 <sub>H</sub>     | 16-Bit DeMUX, $\overline{WRH}$ , A1 |

1) Which FCONCSx registers are affected is dependant on the configuration at P10[14:13] as follows:

11<sub>B</sub> or 01<sub>B</sub> - FCONCS0 is affected

10<sub>B</sub> - FCONCS0 and FCONCS1 are affected

00<sub>B</sub> - FCONCS0..FCONCS4 are affected

The other (unaffected) FCONCS registers retain their default values - refer to the EBC Chapter of this Manual.

**Table 12-9 External start mode-Specific State in EBCMOD0[7:0]**

| Configuration at P10[14:13] | Configuration at P10[12:11] |                           |                           |                           |
|-----------------------------|-----------------------------|---------------------------|---------------------------|---------------------------|
|                             | 00 <sub>B</sub> (0 Segm.)   | 01 <sub>B</sub> (2 Segm.) | 10 <sub>B</sub> (4 Segm.) | 11 <sub>B</sub> (8 Segm.) |
| 00 <sub>B</sub> (5 CS)      | 50 <sub>H</sub>             | 52 <sub>H</sub>           | 54 <sub>H</sub>           | 58 <sub>H</sub>           |
| 01 <sub>B</sub> (1 CS)      | 10 <sub>H</sub>             | 12 <sub>H</sub>           | 14 <sub>H</sub>           | 18 <sub>H</sub>           |
| 10 <sub>B</sub> (2 CS)      | 20 <sub>H</sub>             | 22 <sub>H</sub>           | 24 <sub>H</sub>           | 28 <sub>H</sub>           |
| 11 <sub>B</sub> (0 CS)      | 00 <sub>H</sub>             | 02 <sub>H</sub>           | 04 <sub>H</sub>           | 08 <sub>H</sub>           |

## Startup Configuration and Bootstrap Loading

### 12.6 Bootstrap Loading

Bootstrap Loading is the technique of transferring code to the XC27x5X via a certain interface (usually serial) before the regular code execution out of non-volatile program memory commences. Instead, the XC27x5X executes the previously received code.

This boot-code may be complete (e.g. temporary software for testing or calibration), amend existing code in non-volatile program memory (e.g. with product-specific data or routines), or load additional code (e.g. using higher or more secure protocols). A possible application for bootstrap loading is the programming of virgin Flash memory at the end of a production line, with no external memory or internal Flash required for the initialization code.

The BSL mechanism may be used for standard system startup as well as only for special occasions like system maintenance (firmware update) or end-of-line programming or testing.

The XC27x5X supports bootstrap loading using several protocols/modes:

- Standard UART protocol, loading 32 bytes (see [Section 12.6.2.1](#))
- UART protocol, Enhanced bootstrap loader transferring arbitrary number of bytes (see [Section 12.6.2.2](#))
- Synchronous serial protocol (see [Section 12.6.3](#))
- CAN protocol (see [Section 12.6.4](#))

For a summary of these modes, see also [Table 12-16](#).

#### 12.6.1 General Functionality

Even though each bootstrap loader has its particular functionality, the general handling is the same for all of them.

#### Entering a Bootstrap Loader

Bootstrap loaders are enabled by selecting a specific startup configuration (see [Section 12.1](#)).

The required configuration patterns are described in [Table 12-16](#) for the bootstrap loaders, and are summarized in [Table 12-2](#).

## Startup Configuration and Bootstrap Loading

### Loading the Startup Code

After establishing communication, the BSL enters a loop to receive the respective number of bytes. These bytes are stored sequentially into the on-chip PSRAM, starting at location E0'0000<sub>H</sub>. To execute the loaded code the BSL then points register VECSEG to location E0'0000<sub>H</sub>, i.e. the first loaded instruction, and then jumps to this instruction.

The loaded code may be the final application code or another, more sophisticated, loader routine that adds a transmission protocol to enhance the integrity of the loaded code or data. It may also contain a code sequence to change the system configuration and enable the bus interface to store the received data into external memory.

This process may go through several iterations or may directly execute the final application.

### Exiting Bootstrap Loader Mode

The watchdog timer and the debug system are disabled as long as the Bootstrap loader is active. Watchdog timer and debug system are released automatically when the BSL terminates after having received the last byte from the host.

If 2<sup>nd</sup> level loaders are used, the loader routine should deactivate the watchdog timer via instruction DISWDT to allow for an extended download period.

The XC27x5X will start executing out of user memory as externally configured after a non-BSL reset .

### Interface to the Host

The bootstrap loader communicates with the external host over a predefined set of interface pins. These interface pins are automatically enabled and controlled by the bootstrap loader. The host must connect to these predefined interface pins.

**Table 12-16** indicates the interface pins that are used in each bootstrap loader mode.

## Startup Configuration and Bootstrap Loading

### 12.6.2 Bootstrap Loaders using UART Protocol

XC27x5X users have different possibilities to download code/data in which the communication is based on UART (Universal Asynchronous Receiver and Transmitter) protocol.

#### 12.6.2.1 Standard UART Bootstrap Loader

The standard UART bootstrap loader transfers program code/data via channel 0 of USIC0 (U0C0) into the PSRAM. The U0C0 receiver is only enabled after the identification byte has been transmitted. A half duplex connection to the host is, therefore, sufficient to feed the BSL.

Data is transferred from the external host to the XC27x5X using asynchronous eight-bit data frames without parity (1 start bit, 1 stop bit). The number of data bytes to be received in standard UART boot mode is fixed to 32 bytes, which allows up to 16 two-byte instructions.



**Figure 12-2 Bootstrap Loader Sequence**

The XC27x5X scans the RxD line to receive a zero byte after entering UART BSL mode and the respective initialization. The zero byte is considered as containing one start bit, eight 0 data bits and one stop bit. From the duration of this zero byte it calculates the corresponding baudrate factor with respect to the current CPU clock, initializes the serial interface U0C0 accordingly and switches pin TxD to output. Using this baudrate, an identification byte ( $D5_H$ ) is returned to the host that provides the loaded data.

## Startup Configuration and Bootstrap Loading

Once the identification byte is transmitted, the BSL enters a loop to receive 32 bytes via U0C0. These bytes are stored sequentially into locations E0'0000<sub>H</sub> through E0'001F<sub>H</sub> of the internal PSRAM and then executed.

*Note: For loading more code, two possibilities exist:*

- via a 2<sup>nd</sup>-level loader - see below
- using the **Enhanced UART Bootstrap Loader** - refer to **Section 12.6.2.2**

### Second Level Bootloader

Most probably the initially loaded routine will load additional code or data, as an average application is likely to require substantially more instructions than could fit into 32 bytes. This second receive loop may directly use the pre-initialized interface U0C0 to receive data and store it to arbitrary user-defined locations.

The example code below shows how to fit such a 2<sup>nd</sup>-level loader into the available 32 bytes. This is possible due to the pre-initialized serial channel and the pre-set registers (see **Table 12-10**).

```
;Example for Secondary UART Bootstrap Loader Routine
;-----
TargetStart LIT  '0E00020H'      ;Definition of target area:
TargetEnd   LIT  '0E001FFH'      ;480 bytes in this example
StartOfCode LIT  '0E00100H'      ;Continue executing here...
                                ;...after download

Level2Loader:
    DISWDT                      ;No WDT for further download
    MOV    DPP0, #(PAG TargetStart)
    MOV    R10, #(DPP0:TargetStart);Set pointer to target area
Level2MainLoop:
    MOV    [R1],R3                ;Clear RIF for new byte
Level2RecLoop:
    MOV    R4, [R0]                ;Access PSR
    JNB    R4.14,Level2RecLoop  ;Wait for RIF
    MOVB   [R10],[R2]              ;Copy new byte to target
    CMPI1 R10, #POF (TargetEnd);All bytes received??
    JMPL  cc_NE,Level2MainLoop ;Repeat for complete area
Level2Terminate:
    JMPS  SEG StartOfCode, SOF StartOfCode
```

## Startup Configuration and Bootstrap Loading

### Specific Settings

The following configuration is automatically set when the XC27x5X has entered Standard UART BSL mode:

**Table 12-10 Standard UART BSL-Specific State**

| Item       | Value             | Comments                                     |
|------------|-------------------|----------------------------------------------|
| U0C0_CCR   | 0002 <sub>H</sub> | ASC mode selected for USIC0 Channel 0        |
| U0C0_PCRL  | 0401 <sub>H</sub> | 1 stop bit, three RxD-samples at point 4     |
| U0C0_SCTRL | 0002 <sub>H</sub> | Passive data level = 1                       |
| U0C0_SCTRH | 0707 <sub>H</sub> | 8 data bits                                  |
| U0C0_FDRL  | 43FF <sub>H</sub> | Normal divider mode 1:1 selected             |
| U0C0_BRGH  | 0XXX <sub>H</sub> | Measured PDIV value (zero-byte) in bits[9:0] |
| U0C0_BRGL  | 1C00 <sub>H</sub> | Normal mode, FDIV, 8 clocks/bit              |
| U0C0_DX0CR | 0003 <sub>H</sub> | Data input selection                         |
| DPP1       | 0081 <sub>H</sub> | Points to USIC0 base address <sup>1)</sup>   |
| R0         | 4044 <sub>H</sub> | Pointer to U0C0_PSR <sup>1)</sup>            |
| R1         | 4048 <sub>H</sub> | Pointer to U0C0_PSCR <sup>1)</sup>           |
| R2         | 405C <sub>H</sub> | Pointer to U0C0_RBUF <sup>1)</sup>           |
| R3         | 4000 <sub>H</sub> | Mask to clear RIF <sup>1)</sup>              |

Devices in 144/100-pin package:

|           |                   |                                  |
|-----------|-------------------|----------------------------------|
| P7_IOCR03 | 00B0 <sub>H</sub> | P7.3 is push/pull output (TxD)   |
| P7_IOCR04 | 0020 <sub>H</sub> | P7.4 is input with pull-up (RxD) |

Devices in 64-pin package:

|           |                   |                                  |
|-----------|-------------------|----------------------------------|
| P2_IOCR03 | 00B0 <sub>H</sub> | P2.3 is push/pull output (TxD)   |
| P2_IOCR04 | 0020 <sub>H</sub> | P2.4 is input with pull-up (RxD) |

1) This register setting is provided for a 2<sup>nd</sup>-level loader routine (see at [Page 12-21](#)).

The identification byte identifies the device to be booted. The following codes are defined:

55<sub>H</sub>: 8xC166.

A5<sub>H</sub>: Previous versions of the C167 (obsolete).

B5<sub>H</sub>: Previous versions of the C165.

C5<sub>H</sub>: C167 derivatives.

D5<sub>H</sub>: All devices equipped with identification registers (including the XC27x5X).

## Startup Configuration and Bootstrap Loading

*Note: The identification byte  $D5_H$  does not directly identify a specific derivative. This information can, in this case, be obtained from the identification registers.*

### 12.6.2.2 Enhanced UART Bootstrap Loader

The enhanced UART bootstrap loader transfers program code/data via Channel 0 of USIC0 Module (U0C0) into PSRAM.

Data is transferred from the external host to the XC27x5X using asynchronous eight-bit data frames without parity (1 start bit, 1 stop bit). The length of the code/data is not fixed as in the [Standard UART Bootstrap Loader](#) but can be arbitrary up to the PSRAM total size minus 256 bytes. Also the code execution can start from arbitrary PSRAM address, as well as the initial baudrate can be changed - e.g. increased for faster transfer of long code/data blocks.

The initial steps of this bootloader are the same as of the [Standard UART Bootstrap Loader](#). XC27x5X first scans the RxD line to receive a zero byte, i.e. one start bit, eight 0 data bits and one stop bit. From the duration of this zero byte it calculates the corresponding baudrate factor with respect to the current CPU clock, initializes the serial interface U0C0 accordingly and switches pin TxD to output. Using this baudrate, an identification byte ( $DA_H$ ) is returned to the host.

The next steps in this mode are to process the so-called Bootloader Header as follows:

1. XC27x5X sends the current PDIV divider from U0C0\_BRGH register - the 10-bit value is sent in 2 bytes

*Note: In this bootloader, the multi-byte values are sent in high-to-low order.*

2. XC27x5X receives and sends back to the host a Header\_Code (1B)
3. XC27x5X receives and sends back to the host number of bytes to be transferred Code\_Length (3B)
4. XC27x5X receives and sends back to the host the start address STADD for code-execution (3B)
  - the segment address (highest STADD byte) must equal  $E0_H$  for XC27x5X
5. XC27x5X receives and sends back to the host a value for PDIV divider (2B, bits[9:0] effective only)
  - if the new value is different from the current - the new one is written into U0C0\_BRGH register and a zero confirmation byte is sent back to the host with baudrate already changed
6. XC27x5X receives and sends back to the host a Trailer\_Code (1B)
  - a) if both the Header\_Code and Trailer\_Code are equal to the XC27x5X identification byte ( $DA_H$ ) - the Bootloader sends to the Host a zero byte and continues further;
  - b) if the above condition is not true - the Bootloader sends an identification byte ( $DA_H$ ) to the host and restarts Header processing again from point **1**.

## Startup Configuration and Bootstrap Loading

Once the Header is successfully processed according to the above steps, the Bootstrap loader receives Code\_Length bytes and stores them sequentially starting from the beginning of PSRAM at address E0'0000<sub>H</sub>.

***Attention: The user must care, that the number of Bytes sent is not bigger than available in the device PSRAM minus 256.***

The Bootstrap loader starts code-execution after the last byte is received and stored. The execution is started from address STADD as received within the header.

### Specific Settings

The following configuration is automatically set when the XC27x5X has entered Enhanced UART BSL mode:

**Table 12-11 Enhanced UART BSL-Specific State**

| Item       | Value             | Comments                                     |
|------------|-------------------|----------------------------------------------|
| U0C0_CCR   | 0002 <sub>H</sub> | ASC mode selected for USIC0 Channel 0        |
| U0C0_PCRL  | 0401 <sub>H</sub> | 1 stop bit, three RxD-samples at point 4     |
| U0C0_SCTRL | 0002 <sub>H</sub> | Passive data level = 1                       |
| U0C0_SCTRH | 0707 <sub>H</sub> | 8 data bits                                  |
| U0C0_FDRL  | 43FF <sub>H</sub> | Normal divider mode 1:1 selected             |
| U0C0_BRGH  | 0XXX <sub>H</sub> | PDIV-value as sent by the host inside header |
| U0C0_BRGL  | 1C00 <sub>H</sub> | Normal mode, FDIV, 8 clocks/bit              |
| U0C0_DX0CR | 0003 <sub>H</sub> | Data input selection                         |

Devices in 144/100-pin package:

|           |                   |                                  |
|-----------|-------------------|----------------------------------|
| P7_IOCR03 | 00B0 <sub>H</sub> | P7.3 is push/pull output (TxD)   |
| P7_IOCR04 | 0020 <sub>H</sub> | P7.4 is input with pull-up (RxD) |

Devices in 64-pin package:

|           |                   |                                  |
|-----------|-------------------|----------------------------------|
| P2_IOCR03 | 00B0 <sub>H</sub> | P2.3 is push/pull output (TxD)   |
| P2_IOCR04 | 0020 <sub>H</sub> | P2.4 is input with pull-up (RxD) |

The identification byte identifies the device to be booted. XC27x5X is the first microcontroller family supporting Enhanced UART BSL mode, the code defined for it is DA<sub>H</sub>.

*Note: The identification byte does not directly identify a specific derivative. This information can, in this case, be obtained from the identification registers.*

## Startup Configuration and Bootstrap Loading

### 12.6.2.3 Choosing the Baudrate for the BSL

The calculation of the serial baudrate for U0C0 from the length of the first zero byte that is received, allows the operation of the bootstrap loader of the XC27x5X with a wide range of baudrates. However, the upper and lower limits have to be kept, in order to ensure proper data transfer.

The XC27x5X uses bitfield PDIV to measure the length of the initial zero byte. The quantization uncertainty of this measurement implies the deviation from the real baudrate.

For a correct data transfer from the host to the XC27x5X the maximum deviation between the internal initialized baudrate for U0C0 and the real baudrate of the host should be below 2.5%. The deviation ( $F_B$ , in percent) between host baudrate and XC27x5X baudrate can be calculated via [Equation \(12.1\)](#):

$$F_B = \left| \frac{B_{\text{Contr}} - B_{\text{Host}}}{B_{\text{Contr}}} \right| \times 100\% \quad F_B \leq 2.5\% \quad (12.1)$$

*Note: Function ( $F_B$ ) does not consider the tolerances of oscillators and other devices supporting the serial communication.*

This baudrate deviation is a nonlinear function depending on the system clock and the baudrate of the host. The maxima of the function ( $F_B$ ) increase with the host baudrate due to the smaller baudrate prescaler factors and the implied higher quantization error (see [Figure 12-3](#)).



Figure 12-3 Baudrate Deviation between Host and XC27x5X

## Startup Configuration and Bootstrap Loading

The **minimum baudrate** ( $B_{Low}$  in [Figure 12-3](#)) is determined by the maximum count capacity of bitfield PDIV, when measuring the zero byte, i.e. it depends on the system clock. The minimum baudrate is obtained by using the maximum PDIV count  $2^{10}$  in the baudrate formula. Baudrates below  $B_{Low}$  would cause PDIV to overflow. In this case U0C0 cannot be initialized properly and the communication with the external host is likely to fail.

The **maximum baudrate** ( $B_{High}$  in [Figure 12-3](#)) is the highest baudrate where the deviation still does not exceed the limit, i.e. all baudrates between  $B_{Low}$  and  $B_{High}$  are below the deviation limit.  $B_{High}$  marks the baudrate up to which communication with the external host will work properly without additional tests or investigations.

**Higher baudrates**, however, may be used as long as the actual deviation does not exceed the indicated limit. A certain baudrate (marked I) in [Figure 12-3](#)) may e.g. violate the deviation limit, while an even higher baudrate (marked II) in [Figure 12-3](#)) stays very well below it. Any baudrate can be used for the bootstrap loader provided that the following three prerequisites are fulfilled:

- the baudrate is within the specified operating range for U0C0
- the external host is able to use this baudrate
- the computed deviation error is below the limit.

*Note: When the bootstrap loader mode is entered after a power reset, the bootstrap loader will begin to operate with  $f_{SYS} = f_{IOSC} \times 2$  (approximately 10 MHz) which will limit the maximum baudrate for U0C0.*

*Higher levels of the bootstrapping sequence can then switch the clock generation mode in order to achieve higher baudrates for the download.*

## Startup Configuration and Bootstrap Loading

### 12.6.3 Synchronous Serial Channel Bootstrap Loader

The Synchronous Serial Channel (SSC) bootstrap loader transfers program code/data from an external serial EEPROM via channel 0 of USIC0 (U0C0) into the PSRAM. The XC27x5X is the master, so no additional elements (except for the EEPROM) are required.

The SSC bootstrap loading is a convenient way for initial and basic (go/fail) testing during software development - it allows many various code-versions to be easily started on the target system by re-programming a serial EEPROM.

During SSC bootstrap loading data is transferred from the external EEPROM to the XC27x5X using synchronous eight-bit data frames with MSB first. The number of data bytes to be received in SSC boot mode is user-selectable. The serial clock rate is set to  $f_{SYS}/10$ , which results in 1 MHz after a power reset.

Once SSC BSL mode is entered and the respective initialization done, the XC27x5X first reads the header from the first addresses (00...0) of the target EEPROM.

This header consists of two items:

- The memory identification byte: D5<sub>H</sub>
- The data size field: 1, 2 or 3 bytes, depending on the EEPROM's addressing mode (8-bit, 16-bit or 24-bit, see [Section 12.6.3.1](#))

If both items are valid the BSL enters a loop to read the number of bytes defined by the data size field via U0C0.

These bytes are stored sequentially into PSRAM starting at location E0'0000<sub>H</sub> and are then executed. Therefore, the size of the PSRAM in the respective derivative determines the real maximum block size to be downloaded.

***Attention: The user must care, that the data-size is not bigger than available in the device PSRAM minus 256 and does not exceed 32512.***

An invalid header (identification byte ≠ D5<sub>H</sub>, data size field = 0 or greater than allowed) is indicated by toggling the CS line low 3 times. This helps debugging during the system setup phase.

## Startup Configuration and Bootstrap Loading

### 12.6.3.1 Supported EEPROM Types

The XC27x5X's SSC bootstrap loader assumes an SPI-compatible EEPROM (25xxx series). It supports devices with 8-bit, 16-bit as well as 24-bit addressing. The connected EEPROM type is determined by examining the received header bytes, as indicated in **Table 12-12**.

*Note: The data size  $n$  is in bytes.*

**Table 12-12 Determining the EEPROM Type**

| SSC Frame |        | EEPROM with 8-bit addressing connected |                      | EEPROM with 16-bit addressing connected |                      | EEPROM with 24-bit addressing connected |                      |
|-----------|--------|----------------------------------------|----------------------|-----------------------------------------|----------------------|-----------------------------------------|----------------------|
| N         | data   | P11-send                               | P11-receive          | P11-send                                | P11-receive          | P11-send                                | P11-receive          |
| 1         | $03_H$ | Read command                           | $XX_H$ default level | Read command                            | $XX_H$ default level | Read command                            | $XX_H$ default level |
| 2         | $00_H$ | Address                                | $XX_H$               | Address_H                               | $XX_H$               | Address_H                               | $XX_H$               |
| 3         | $00_H$ | dummy                                  | $D5_H$ :Ident. B     | Address_L                               | $XX_H$               | Address_M                               | $XX_H$               |
| 4         | $00_H$ | dummy                                  | Size $n$             | dummy                                   | $D5_H$ :Ident. B     | Address_L                               | $XX_H$               |
| 5         | $00_H$ | dummy                                  | Data Byte 1          | dummy                                   | Size $n$ ,high B     | dummy                                   | $D5_H$ :Ident. B     |
| 6         | $00_H$ | dummy                                  | Data Byte 2          | dummy                                   | Size $n$ ,low B      | dummy                                   | Size $n$ ,high B     |
| 7         | $00_H$ | dummy                                  | Data Byte 3          | dummy                                   | Data Byte 1          | dummy                                   | Size $n$ ,mid B      |
| 8         | $00_H$ | dummy                                  | Data Byte 4          | dummy                                   | Data Byte 2          | dummy                                   | Size $n$ ,low B      |
| 9         | ...    | dummy                                  | Data Byte 5<br>...n  | dummy                                   | Data Byte 3<br>...n  | dummy                                   | Data Byte 1<br>...n  |

*Note: The value of the returned default bytes (indicated as  $XX_H$ ) depends on the employed EEPROM type.*

## Startup Configuration and Bootstrap Loading

### 12.6.3.2 Specific Settings

When the XC27x5X has entered the SSC BSL mode, the following configuration is automatically set:

**Table 12-13 SSC BSL-Specific State**

| Item       | Value             | Comments                                      |
|------------|-------------------|-----------------------------------------------|
| U0C0_CCR   | 0001 <sub>H</sub> | SSC mode selected for USIC0 Channel 0         |
| U0C0_PCRL  | 0011 <sub>H</sub> | SSC master mode, frequency from fPPP          |
| U0C0_PCRH  | 8000 <sub>H</sub> | MCLK generation is enabled                    |
| U0C0_SCTRL | 0103 <sub>H</sub> | MSB first, passive data level=1               |
| U0C0_SCTRH | 073F <sub>H</sub> | 8 data bits, infinite frame                   |
| U0C0_DX0CR | 0015 <sub>H</sub> | Data input selection                          |
| U0C0_FDRL  | 43FF <sub>H</sub> | Normal divider mode 1:1 selected              |
| U0C0_BRGL  | 0000 <sub>H</sub> | Normal mode, FDIV - default value after reset |
| U0C0_BRGH  | 8004 <sub>H</sub> | Passive levels MCLK/SCLK=0, PDIV=4            |
| P2_IOCR03  | 00D0 <sub>H</sub> | P2.3 is open-drain output (MTSR)              |
| P2_IOCR04  | 0020 <sub>H</sub> | P2.4 is input with pull-up (MRST)             |
| P2_IOCR05  | 00D0 <sub>H</sub> | P2.5 is open-drain output (SCLK)              |
| P2_IOCR06  | 00C0 <sub>H</sub> | P2.6 is open-drain output (SLS)               |

## Startup Configuration and Bootstrap Loading

### 12.6.4 CAN Bootstrap Loader

The CAN bootstrap loader transfers program code/data via node 0 of the MultiCAN module into the PSRAM. Data is transferred from the external host to the XC27x5X using eight-byte data frames. The number of data frames to be received is programmable and determined by the 16-bit data message count value DMSGC.

The communication between XC27x5X and external host is based on the following three CAN standard frames:

- Initialization frame - sent by the external host to the XC27x5X
- Acknowledge frame - sent by the XC27x5X to the external host
- Data frame(s) - sent by the external host to the XC27x5X

The initialization frame is used in the XC27x5X for baud rate detection. After a successful baud rate detection is reported to the external host by sending the acknowledge frame, data is transmitted using data frames. **Table 12-14** shows the parameters and settings for the three utilized CAN standard frames.

*Note: The CAN bootstrap loader requires a point-to-point connection with the host, i.e. the XC27x5X must be the only CAN node connected to the network. A crystal with at least 4 MHz is required for CAN bootstrap loader operation.*

#### Initialization Phase

The first BSL task is to determine the CAN baud rate at which the external host is communicating. Therefore the external host must send initialization frames continuously to the XC27x5X. The first two data bytes of the initialization frame must include a 2-byte baud rate detection pattern ( $5555_H$ ), an 11-bit (sent in 2 bytes) identifier ACKID<sup>1)</sup> for the acknowledge frame, a 16-bit data message count value DMSGC, and an 11-bit (2-byte) identifier DMSGID<sup>1)</sup> to be used by the data frame(s).

The CAN baud rate is determined by analyzing the received baud rate detection pattern ( $5555_H$ ) and the baud rate registers of the MultiCAN module are set accordingly. The XC27x5X is now ready to receive CAN frames with the baud rate of the external host.

#### Acknowledge Phase

In the acknowledge phase, the bootstrap loader waits until it receives the next correctly recognized initialization frame from the external host, and acknowledges this frame by generating a dominant bit in its ACK slot. Afterwards, the bootstrap loader transmits an acknowledge frame back to the external host, indicating that it is now ready to receive data frames. The acknowledge frame uses the message identifier ACKID that has been received with the initialization frame.

1) The CAN bootstrap loader copies the two identifier bytes received in the initialization frame directly to register MOAR. Therefore, the respective fields in the initialization frame must contain the intended identifier padded with two dummy bits at the lower end and extended with bitfields IDE (=0<sub>B</sub>) and PRI (=01<sub>B</sub>) at the upper end.

## Startup Configuration and Bootstrap Loading

To summarize: the external host must send initialization frames (the content as above defined) continuously until an acknowledge frame is received back from the XC27x5X having the same message identifier as sent by the host in data bytes 2/3 from the initialization frame, then the **Data Transmission Phase** begins.

### Data Transmission Phase

In the data transmission phase, data frames are sent by the external host and received by the XC27x5X. The data frames use the 11-bit data message identifier DMSGID that has been sent with the initialization frame. Eight data bytes are transmitted with each data frame. The first data byte is stored in PSRAM at  $E0'0000_H$ . Consecutive data bytes are stored at incrementing addresses.

Both communication partners evaluate the data message count DMSGC until the requested number of CAN data frames has been transmitted. After the reception of the last CAN data frame, the bootstrap loader finishes and executes the loaded code.

### Timing Parameters

There are no general restrictions for CAN timings of the external host. During the initialization phase the external host transmits initialization frames. If no acknowledge frame is sent back within a certain time as defined in the external host (e.g. after a dedicated number of initialization frame transmissions), the external host can decide that the XC27x5X is not able to establish the CAN boot communication link.

**Table 12-14 CAN Bootstrap Loader Frames**

| Frame Type           | Parameter      | Description                                                                                      |
|----------------------|----------------|--------------------------------------------------------------------------------------------------|
| Initialization Frame | Identifier     | 11-bit, don't care                                                                               |
|                      | DLC = 8        | Data length code, 8 bytes within CAN frame                                                       |
|                      | Data bytes 0/1 | Baud rate detection pattern ( $5555_H$ )                                                         |
|                      | Data bytes 2/3 | Acknowledge message identifier ACKID (complete register contents)                                |
|                      | Data bytes 4/5 | Data message count DMSGC, 16-bit                                                                 |
|                      | Data bytes 6/7 | Data message identifier DMSGID (complete register contents)                                      |
| Acknowledge Frame    | Identifier     | Acknowledge message identifier ACKID as received by data bytes [3:2] of the initialization frame |
|                      | DLC = 4        | Data length code, 4 bytes within CAN frame                                                       |
|                      | Data bytes 0/1 | Contents of bit-timing register                                                                  |
|                      | Data bytes 2/3 | Copy of acknowledge identifier from initialization frame                                         |

## Startup Configuration and Bootstrap Loading

**Table 12-14 CAN Bootstrap Loader Frames (cont'd)**

| Frame Type | Parameter         | Description                                                                            |
|------------|-------------------|----------------------------------------------------------------------------------------|
| Data frame | Identifier        | Data message identifier DMSGID as sent by data bytes [7:6] of the initialization frame |
|            | DLC = 8           | Data length code, 8 bytes within CAN frame                                             |
|            | Data bytes 0 to 7 | Data bytes, assigned to increasing destination (PSRAM) addresses                       |

**12.6.4.1 Specific Settings**

When the XC27x5X has entered the CAN BSL mode, the following configuration is automatically set:

**Table 12-15 CAN BSL-Specific State**

| Item         | Value             | Comments                                      |
|--------------|-------------------|-----------------------------------------------|
| P2_IOCR05    | 00A0 <sub>H</sub> | P2.5 is push/pull output (Tx <sub>D</sub> )   |
| P2_IOCR06    | 0020 <sub>H</sub> | P2.6 is input with pull-up (Rx <sub>D</sub> ) |
| SCU_HPOSCCON | 0030 <sub>H</sub> | OSC_HP enabled, External Crystal/Clock mode   |
| SCU_SYSCON0  | 0001 <sub>H</sub> | OSC_HP selected as system clock               |
| CAN_MOCTR0L  | 0008 <sub>H</sub> | Message Object 0 Control, low                 |
| CAN_MOCTR0H  | 00A0 <sub>H</sub> | Message Object 0 Control, high                |
| CAN_MOCTR1L  | 0000 <sub>H</sub> | Message Object 1 Control, low                 |
| CAN_MOCTR1H  | 0F28 <sub>H</sub> | Message Object 1 Control, high                |
| CAN_MOFCR1H  | 0400 <sub>H</sub> | Message Object Function Control, high         |
| CAN_MOAMR0H  | 1FFF <sub>H</sub> | Message Object 0 - Acceptance Mask bit set    |
| CAN_NPCR0    | 0003 <sub>H</sub> | Data input selection                          |

## Startup Configuration and Bootstrap Loading

### 12.6.5 Summary of Bootstrap Loader Modes

This table summarizes the external hardware provisions that are required to activate a bootstrap loader in a system.

**Table 12-16 Configuration Data for Bootstrap Loader Modes**

| Bootstrap Loader Mode | Configuration on P10.[3:0] <sup>1)</sup> | Receive Line from Host      | Transmit Line to Host                    | Transferred Data                 | Supported Host Speed                               |
|-----------------------|------------------------------------------|-----------------------------|------------------------------------------|----------------------------------|----------------------------------------------------|
| Standard UART         | $x110_B$                                 | RxD = P7.4<br>(100/144-pin) | TxD = P7.3<br>(100/144-pin)              | 32 bytes                         | 2.4 - 19.2 kbaud                                   |
|                       |                                          | RxD = P2.4<br>(64-pin)      | TxD = P2.3<br>(64-pin)                   |                                  |                                                    |
| Enhanced UART         | $x010_B$                                 | RxD = P7.4<br>(100/144-pin) | TxD = P7.3<br>(100/144-pin)              | l bytes <sup>2)</sup>            | 2.4-19.2 kbaud at start, then changeable by Header |
|                       |                                          | RxD = P2.4<br>(64-pin)      | TxD = P2.3<br>(64-pin)                   |                                  |                                                    |
| Sync. Serial          | $1001_B$                                 | MRST = P2.4                 | MTSR = P2.3<br>SCLK = P2.5<br>SLS = P2.6 | m bytes <sup>3)</sup>            | ---<br>(controlled by XC27x5X)                     |
| MultiCAN              | $x101_B$                                 | RxDC0 = P2.6                | TxDC0 = P2.5                             | $8 \times n$ bytes <sup>4)</sup> | 125 - 500 kBaud                                    |

1) x means that the level on the corresponding pin is irrelevant.

2) l = Code\_Length sent by the host, the values allowed are 1...(PSRAM\_size-256).

3) m = data size read from EEPROM, the values allowed are 1...(PSRAM\_size-256) but not bigger than 32512.

4) n = DMSGC, Data Message Count sent by the host with Initialization frame, the values allowed are 1...(PSRAM\_size-256)/8.

## 13 Debug System

The XC27x5X includes an On-Chip Debug Support (OCDS) system, which provides convenient debugging, controlled directly by an external tool via debug interface pins.

### OCDS Components

- [Debug Interface](#)
- [Cerberus](#)
- [OCDS Module](#)

### On-Chip Debug Support (OCDS)

The OCDS system ([Figure 13-1](#)) supports a broad range of debug features including breakpoints and the tracing of memory locations. A typical application of the OCDS is to debug user software running on the XC27x5X in a real time system environment.



**Figure 13-1 OCDS Block Diagram**

The OCDS is controlled by an external tool via the [Debug Interface](#). The physical interface is either DAP or JTAG plus an optional break interface with one or two pins. The break interface supports very low latency triggers between XC27x5X and tool and/or system environment if needed. The memory mapped OCDS registers are accessible via the DAP/JTAG interface using Cerberus. In addition there is a limited set of special Cerberus debug IO instructions. As an alternative the OCDS can be controlled by a debug monitor program, which communicates with the tool over a user interface like CAN. The OCDS system interacts with the CPU through an injection interface to allow execution of Cerberus-generated instructions, and through a break port.

## OCDS System Features

- Hardware, software and external pin breakpoints
- Trigger action can be CPU-halt, monitor call, data transfer and/or BRKOUT signal
- Read/write access to the whole address space
- Single stepping
- Non intrusive debugging (no debug monitor needed)
- Debug also possible over user interface like CAN (with debug monitor)
- DAP or JTAG interface and optional break interface
- Injection of arbitrary CPU instructions
- Fast memory tracing through transfer to external bus (if available)

### 13.1 Debug Interface

The Debug Interface allows to access OCDS resources. Data can be transferred to/from all on- and off-chip memories and memory mapped control registers.

#### Features and Functions

- Independent interface for OCDS
- DAP (Device Access Port) or alternatively JTAG
- Break interface for external trigger input and signaling of internal triggers
- Generic memory access functionality
- Independent data transfer channel for e.g. programming of flash memory

The Debug Interface consists of:

- **DAP Interface**
- Alternatively **JTAG Interface** based on the IEEE 1149.1 JTAG standard
- Two additional XC27x5X specific signals - **OCDS Break-Interface**

**Note: The DAP/JTAG clock frequency must be below the current CPU frequency.**

#### DAP Interface

The DAP interface is a device access port standardized for the latest Infineon microcontrollers. It reduces the pin count to two pins and offers high noise immunity and robustness.

This interface consists of the signals:

- **DAP0** - clock
- **DAP1** - Serial data input/output

#### JTAG Interface

The JTAG interface is a standardized and dedicated port, primarily provided for boundary scan board tests.

This interface consists of the JTAG IEEE.1149.1-2001 standard signals:

## Debug System

- **TDI** - Serial data input
- **TDO** - Serial data output
- **TCK** - JTAG clock
- **TMS** - State machine control signal

### OCDS Break-Interface

Two optional additional signals provide a direct trigger interface between the Debugger and XC27x5X **OCDS Module**:

- **BRKIN** (BReaK IN request) allows to trigger directly one of the **Debug Actions**.
- **BRKOUT** (BReaK OUT signal) can be activated by OCDS to notify the external world that some predefined debug event has happened.

### 13.1.1 Routing of Debug Signals

The signals used to connect an external debugger via the JTAG interface and the break interface usually conflict with the requirements to have as many IO pins as possible for the application. In the XC27x5X, these signals are only provided as alternate functions (no dedicated pins). To minimize the impact caused by the debug interface pins, these signals can be mapped to various positions. Thus, each application can select the variant with the least impact. This is controlled via the Debug Pin Routing Register **DBGPRR**. Pin **BRKOUT** can be assigned to pins P6.0, P10.11, P1.5, or P9.3 as a standard alternate output signal via the respective IOC register.

#### 13.1.1.1 Register DBGPRR

This register controls the pin mapping of the DAP/JTAG pins. The position options A/B/C/D/E are controlled with the register **DBGPRR**. The bit field description of **DBGPRR** includes all position options for all derivatives of the family with DAP/JTAG Interface. For derivatives with lower pin count packages, unavailable positions shall be treated as reserved.

The **DBGPRR** is set during start-up as described in [Section 12.3.2](#).

#### DBGPRR

##### Debug Pin Routing Register

**ESFR (F06E<sub>H</sub>/37<sub>H</sub>)**

**Reset Value: 0000<sub>H</sub>**

| 15        | 14        | 13         | 12        | 11          | 10       | 9            | 8 | 7          | 6 | 5          | 4 | 3          | 2 | 1          | 0 |
|-----------|-----------|------------|-----------|-------------|----------|--------------|---|------------|---|------------|---|------------|---|------------|---|
| TRS<br>TL | TRS<br>TS | TRS<br>TGT | DBG<br>EN | JTAG<br>DAP | DPR<br>E | DPR<br>BRKIN |   | DPR<br>TCK |   | DPR<br>TMS |   | DPR<br>TDI |   | DPR<br>TDO |   |

## Debug System

| Field           | Bits  | Type | Description                                                                                                                                                                                                                          |
|-----------------|-------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>DPRTDO</b>   | [1:0] | rw   | <b>Debug Pin Routing for DAP1/TDO</b><br>$00_B$ Position A is used for TDO/DAP1, P7.0<br>$01_B$ Position B is used for TDO/DAP1, P10.12<br>$10_B$ Position C is used for TDO/DAP1, P7.0<br>$11_B$ Position D is used for TDO, P10.12 |
| <b>DPRTDI</b>   | [3:2] | rw   | <b>Debug Pin Routing for TDI</b><br>$00_B$ Position A is used, P5.2<br>$01_B$ Position B is used, P10.10<br>$10_B$ Position C is used, P7.2<br>$11_B$ Position D is used, P8.3                                                       |
| <b>DPRTMS</b>   | [5:4] | rw   | <b>Debug Pin Routing for TMS</b><br>$00_B$ Position A is used, P5.4<br>$01_B$ Position B is used, P10.11<br>$10_B$ Position C is used, P7.3<br>$11_B$ Position D is used, P8.4                                                       |
| <b>DPRTCK</b>   | [7:6] | rw   | <b>Debug Pin Routing for DAP0/TCK</b><br>$00_B$ Position A is used for TCK/DAP0, P2.9<br>$01_B$ Position B is used for TCK/DAP0, P10.9<br>$10_B$ Position C is used for TCK/DAP0, P7.4<br>$11_B$ Position D is used for TCK, P8.5    |
| <b>DPRBRKIN</b> | [9:8] | rw   | <b>Debug Pin Routing for BRKIN</b><br>$00_B$ Position A is used, P5.10<br>$01_B$ Position B is used, P10.8<br>$10_B$ Position C is used, P7.1<br>$11_B$ Position D is used, P8.6                                                     |
| <b>DPRE</b>     | [10]  | rw   | <b>Selection of Position E for DAP/JTAG</b><br>Mapping: DAP0/TCK P13.6, DAP1/TDO P13.8, TMS P13.3, TDI P13.5.<br>$0_B$ Position E is not used<br>$1_B$ Position E is used                                                            |
| <b>JTAG_DAP</b> | [11]  | rw   | <b>Selection of Debug Interface</b><br>$0_B$ DAP is used<br>$1_B$ JTAG is used                                                                                                                                                       |
| <b>DBGEN</b>    | [12]  | rw   | <b>Enable for selected Debug Interface</b><br>$0_B$ Interface is disabled<br>$1_B$ Interface is enabled                                                                                                                              |

| Field  | Bits | Type | Description                                                                                                                                 |
|--------|------|------|---------------------------------------------------------------------------------------------------------------------------------------------|
| TRSTGT | [13] | rw   | <b>Gating of TRST Pin</b><br>0 <sub>B</sub> DAP/JTAG reset is internally held active<br>1 <sub>B</sub> TRST pin is routed to DAP/JTAG reset |
| TRSTS  | [14] | rh   | <b>TRST Pin Value</b><br>Current value of TRST pin                                                                                          |
| TRSTL  | [15] | rh   | <b>Latched TRST Pin Start-up Value</b><br>Value of TRST pin latched by PORST release                                                        |

## 13.2 OCDS Module

The application of the OCDS Module is to debug user software running on the CPU in the customer's system. This is done with an external debugger, which controls the OCDS Module via the independent **Debug Interface**.

### Features

- Hardware, software and external pin breakpoints
- Hardware trigger generation for breakpoints and external pin output
  - Four single address or two address ranges for instruction or data
  - Combination of instruction (range) and data address (range)
  - Combination of data address (range) and data value (range)
  - Task ID, optional in combination with address (range) for instruction or data
  - Masked comparisons for addresses and data
- The OCDS can also be configured by a debug monitor program
- Single stepping with monitor or CPU halt
- Higher priority interrupts can still be served if CPU is halted
- Instruction pointer visible in Halt Mode

### Basic Concept

The on chip debug concept is split up into two parts. The first part covers the generation of debug events and the second part defines what actions are taken when a debug event is generated.

- Debug events:
  - **Hardware Breakpoints**
  - **Software Breakpoints**
  - **Break Pin Input** activated
- Debug event actions:
  - **Halt Mode** of the CPU
  - **Call a Monitor**

## Debug System

- Triggered Transfer
- Activate External Pin



**Figure 13-2 OCDS Concept: Block Diagram**

### 13.2.1 Debug Events

The Debug Events can come from a few different sources.

#### Hardware Breakpoints

The Hardware Breakpoint is a debug-event, raised when a single or a combination of multiple trigger-signals are matching with the programmed conditions. The following hardware trigger sources can be used:

**Table 13-1 Hardware Triggers**

| Trigger Source                              | Size        |
|---------------------------------------------|-------------|
| Task Identifier                             | 16 bits     |
| Instruction Pointer                         | 24 bits     |
| Data address of reads (two buses monitored) | 2 × 24 bits |
| Data address of writes                      | 24 bits     |
| Data value (reads or writes)                | 16 bits     |

## Software Breakpoints

A special SBRK (Software BReaK) instruction is defined with opcode 0x8C00. It can be used for instance by a debugger to temporarily replace code held in RAM in order to implement Software Breakpoints. When the SBRK instruction has been decoded and it reaches the execute stage, the whole pipeline is canceled including the SBRK instruction. This implies that the next instruction will be fetched from the address the SBRK was found at.

The further behavior is dependent on how OCDS has been programmed:

- if the OCDS is enabled and the software breakpoints are also enabled, then the CPU goes into **Halt Mode**
- if the OCDS is disabled or the software breakpoints are disabled, then the Software Break Trap (SBRKTRAP) is executed - Class A Trap, number 08<sub>H</sub>

## Break Pin Input

An external debug break pin (BRKIN) is provided to allow the debugger to asynchronously interrupt the processor.

### 13.2.2 Debug Actions

When the OCDS is enabled and a debug event is generated, one of the following actions is taken:

#### Triggered Transfer

One of the actions that can be specified to occur on a debug event being raised is to trigger the **Cerberus**:

- to execute a Data Transfer. This can be used in critical routines where the system cannot be interrupted to transfer a memory location
- to inject an instruction to the CPU, using this mechanism, an arbitrary instruction can be injected into the XC27x5X pipeline

#### Halt Mode

Upon this Action the OCDS Module sends a Break-Request to the CPU.

The CPU accepts this request, if the OCDS Break Level is higher than current CPU priority level. In case a Break-Request is accepted, the system suspends execution with halting the instruction flow.

The Halt Mode can be still interrupted by higher priority user interrupts. It then relies on the external debugger system to interrogate the target purely through reading and updating via the debug interface.

## Call a Monitor

One of the possible actions to be taken when a debug event is raised is to call a Monitor Program. This quick entry to a Monitor allows a flexible debug environment to be defined which is capable of satisfying many of the requirements for efficient debugging of a real time system. In the common case the Monitor has the highest priority and can not be interrupted by any other requesting source.

It is also possible to have an Interruptible Monitor Program. In such a case safety critical code can be still served while the Monitor (Debugger) is active, which gives a maximum flexibility to the user.

## Activate External Pin

This action activates the external pin **BRKOUT** of the **OCDS Break-Interface**. It can be used in critical routines where the system cannot be interrupted to signal to the external world that a particular event has happened. Note that the code execution timing is not affected.

## 13.3 Cerberus

Cerberus is the module which provides and controls all the operations necessary to interact between the external debugger (via the **Debug Interface**), the **OCDS Module** and the internal system of XC27x5X.

### Features

- DAP/JTAG interface is used as control and data channel
- Generic read/write functionality (RW mode) with access to the whole address space
- Reading and writing of general-purpose registers (GPRs)
- Injection of arbitrary instructions
- External host controls all transactions
- All transactions are available at normal run time and in halt mode
- Priority of transactions can be configured
- Full support for communication between the monitor and debugger
- Optional error protection
- Tracing memory locations through transferring values to the external bus
- Analysis register for internal bus locking situations

The target application of Cerberus is to use the DAP/JTAG interface as an independent port for on-chip debug support. The external debugger can access the OCDS registers and arbitrary memory locations with the injection mechanism.

### 13.3.1 Functional Overview

Cerberus is operated by an external debugger across the DAP/JTAG interface. The Debugger uses Cerberus IO Instructions to perform bidirectional data-transfers. Cerberus has two main modes of operation:

#### Read/Write (RW) Mode

RW Mode is the most common way to operate Cerberus. This mode is used to read and write memory locations or to inject instructions into the CPU pipeline. The injection interface to the CPU is actively used in this mode.

All Cerberus IO Instructions can be used in RW mode. The access to any memory location is performed with injected instructions, as a PEC transfer.

#### Communication (COM) Mode

In COM mode the debugger communicates with a monitor program running on the CPU. The difference to **Read/Write (RW) Mode** is that the read or write request is not actively executed. It just sets request bits in a CPU accessible status register to signal the monitor, that the debugger wants to send or receive a value. The monitor has to poll this status register, e.g. triggered by a timer interrupt.

COM Mode is the default mode after reset. It can be used to exchange keys with the application software of a locked (RW Mode disabled) device and to unlock RW Mode only in case of matching keys.

## 13.4 Emulation Device

The XC27x5X can be emulated using an MCDS (Multi-Core Debug Solution) based Emulation Device with an on-chip trace buffer ([Figure 13-3](#)). For availability of such an emulator please contact your Infineon tool partner.



**Figure 13-3 Emulation Device Block Diagram**

### 13.4.1 MCDS Use Cases

MCDS allows non intrusive tracing and triggering for debugging, performance analysis and data measurement.

#### Debugging

- Halt on very complex trigger conditions
- Record trace around bug
- Halt (suspend) system when trace buffer full. Read out and continue
- Highly compressed or cycle accurate trace

## Performance Analysis

- Continuous measurement of performance indicators
- Trigger on performance indicators

## Data Measurement

- Continuous trace of data writes or reads
- Qualified by address ranges and e.g. software task

### 13.4.2 MCDS Features

MCDS provides a rich set of features, which allow a very detailed analysis of the software and system behavior on all levels.

#### CPU Program Trace

- Complete program trace for the 24 bit instruction pointer
- Four independent range comparators

#### CPU Ownership Trace

- Complete trace of the pipeline “user” (e.g. PEC channel)
- Two independent masked comparators for data transfer qualification

#### CPU Status Trace

- Complete trace of the execution mode of the CPU
- Non-intrusive access to the current status.

#### Write Data Trace

- Complete trace of write-back transactions (24 bit address, 8 or 16 bit data)
- Four independent range comparators on the absolute write address
- Four independent signed data comparators on the data value

#### Read Data Trace

- Complete trace of non CPU memory read transactions (24 bit addr., 8 or 16 bit data)
- Four independent range comparators on the absolute address
- Four independent signed data comparators on the data value

#### Trace and Trigger Control

- Dedicated programmable trace enables for each Trace Unit
- Trigger output to OCDS
- Eight universal 16 bit counters
- Programmable combinations of triggers as count and clear signals

## Debug System

- Programmable limit comparator in each counter
- Passing a limit is available as unique trigger for each counter
- The counter values can be traced
- Counters can be cascaded to implement state machines
- Pre-scaled reference clock available as trigger
- Four performance indicator signals directly from the CPU

### Watch-point Trace

- Messages for eight different watch-points
- Messages containing the current count value of any event/performance Counter

### Time Stamping

- Precise time stamps based on the emulation clock (32 bit)
- Precise time stamps based on a reference clock (32 bit)
- Programmable cyclic trigger based on reference clock

## 13.5 Boundary-Scan

The XC27x5X eases board-level analysis in the application system by providing Boundary-Scan according to the IEEE standard 1149.1. It supports testing of the interconnections between several devices mounted on a PCB.

Boundary-Scan is accomplished via the JTAG module, using standard JTAG instructions (IEEE1149.1).

*Note: For Boundary-Scan to operate properly, the JTAG interface must use the default pins. The reset value of register DBGPRR ensures this.*

### Initialization of Boundary-Scan

The following sequence is defined to activate Boundary-Scan mode:

- Set PORST = 1; TRST = 1; TESTM = 1
- Negative Pulse on PORST
- Wait for Power Domain to startup.
- Negative pulse on TRST to reset the JTAG controller.

Now the test access port for Boundary-Scan is enabled. The Boundary-Scan test can be used for board test with instructions like PRELOAD and EXTEST.

## Instruction Set Summary

## 14 Instruction Set Summary

This chapter briefly summarizes the XC27x5X's instructions ordered by instruction classes. This provides a basic understanding of the XC27x5X's instruction set, the power and versatility of the instructions and their general usage.

A **detailed description** of each single instruction, including its operand data type, condition flag settings, addressing modes, length (number of bytes) and object code format is provided in the “**Instruction Set Manual**” for the XC2000 Family. This manual also provides tables ordering the instructions according to various criteria, to allow quick references.

### Summary of Instruction Classes

Grouping the various instruction into classes aids in identifying similar instructions (e.g. SHR, ROR) and variations of certain instructions (e.g. ADD, ADDB). This provides an easy access to the possibilities and the power of the instructions of the XC27x5X.

*Note: The used mnemonics refer to the detailed description.*

**Table 14-1 Arithmetic Instructions**

|                                                |      |       |
|------------------------------------------------|------|-------|
| Addition of two words or bytes:                | ADD  | ADDB  |
| Addition with Carry of two words or bytes:     | ADDC | ADDCB |
| Subtraction of two words or bytes:             | SUB  | SUBB  |
| Subtraction with Carry of two words or bytes:  | SUBC | SUBCB |
| 16 × 16 bit signed or unsigned multiplication: | MUL  | MULU  |
| 16/16 bit signed or unsigned division:         | DIV  | DIVU  |
| 32/16 bit signed or unsigned division:         | DIVL | DIVLU |
| 1's complement of a word or byte:              | CPL  | CPLB  |
| 2's complement (negation) of a word or byte:   | NEG  | NEGB  |

**Table 14-2 Logical Instructions**

|                                       |     |      |
|---------------------------------------|-----|------|
| Bitwise ANDing of two words or bytes: | AND | ANDB |
| Bitwise ORing of two words or bytes:  | OR  | ORB  |
| Bitwise XORing of two words or bytes: | XOR | XORB |

**Instruction Set Summary**
**Table 14-3 Compare and Loop Control Instructions**

|                                                               |       |       |
|---------------------------------------------------------------|-------|-------|
| Comparison of two words or bytes:                             | CMP   | CMPB  |
| Comparison of two words with post-increment by either 1 or 2: | CMPI1 | CMPI2 |
| Comparison of two words with post-decrement by either 1 or 2: | CMPD1 | CMPD2 |

**Table 14-4 Boolean Bit Manipulation Instructions**

|                                                                                    |       |       |
|------------------------------------------------------------------------------------|-------|-------|
| Manipulation of a maskable bit field in either the high or the low byte of a word: | BFLDH | BFLDL |
| Setting a single bit (to '1'):                                                     | BSET  | -     |
| Clearing a single bit (to '0'):                                                    | BCLR  | -     |
| Movement of a single bit:                                                          | BMOV  | -     |
| Movement of a negated bit:                                                         | BMOVN | -     |
| ANDing of two bits:                                                                | BAND  | -     |
| ORing of two bits:                                                                 | BOR   | -     |
| XORing of two bits:                                                                | BXOR  | -     |
| Comparison of two bits:                                                            | BCMP  | -     |

**Table 14-5 Shift and Rotate Instructions**

|                                                          |      |   |
|----------------------------------------------------------|------|---|
| Shifting right of a word:                                | SHR  | - |
| Shifting left of a word:                                 | SHL  | - |
| Rotating right of a word:                                | ROR  | - |
| Rotating left of a word:                                 | ROL  | - |
| Arithmetic shifting right of a word (sign bit shifting): | ASHR | - |

**Table 14-6 Prioritize Instruction**

|                                                                                                            |       |   |
|------------------------------------------------------------------------------------------------------------|-------|---|
| Determination of the number of shift cycles required to normalize a word operand (floating point support): | PRIOR | - |
|------------------------------------------------------------------------------------------------------------|-------|---|

**Instruction Set Summary**
**Table 14-7 Data Movement Instructions**

|                                                                                     |       |       |
|-------------------------------------------------------------------------------------|-------|-------|
| Standard data movement of a word or byte:                                           | MOV   | MOVB  |
| Data movement of a byte to a word location with either sign or zero byte extension: | MOVBS | MOVHZ |

*Note: The data movement instructions can be used with a big number of different addressing modes including indirect addressing and automatic pointer in-/decrementing.*

**Table 14-8 System Stack Instructions**

|                                                                                                                               |      |   |
|-------------------------------------------------------------------------------------------------------------------------------|------|---|
| Pushing of a word onto the system stack:                                                                                      | PUSH | – |
| Popping of a word from the system stack:                                                                                      | POP  | – |
| Saving of a word on the system stack, and then updating the old word with a new value (provided for register bank switching): | SCXT | – |

**Table 14-9 Jump Instructions**

|                                                                                                                                                                                                                                |      |      |      |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|------|
| Conditional jumping to an either absolutely, indirectly, or relatively addressed target instruction within the current code segment:                                                                                           | JMPA | JMPI | JMPR |
| Unconditional jumping to an absolutely addressed target instruction within any code segment:                                                                                                                                   | JMPS | –    | –    |
| Conditional jumping to a relatively addressed target instruction within the current code segment depending on the state of a selectable bit:                                                                                   | JB   | JNB  | –    |
| Conditional jumping to a relatively addressed target instruction within the current code segment depending on the state of a selectable bit with a post-inversion of the tested bit in case of jump taken (semaphore support): | JBC  | JNBS | –    |

**Instruction Set Summary**
**Table 14-10 Call Instructions**

|                                                                                                                                                                        |       |       |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|
| Conditional calling of an either absolutely or indirectly addressed subroutine within the current code segment:                                                        | CALLA | CALLI |
| Unconditional calling of a relatively addressed subroutine within the current code segment:                                                                            | CALLR | -     |
| Unconditional calling of an absolutely addressed subroutine within any code segment:                                                                                   | CALLS | -     |
| Unconditional calling of an absolutely addressed subroutine within the current code segment plus an additional pushing of a selectable register onto the system stack: | PCALL | -     |
| Unconditional branching to the interrupt or trap vector jump table in code segment <VECSEG>:                                                                           | TRAP  | -     |

**Table 14-11 Return Instructions**

|                                                                                                                                        |      |   |
|----------------------------------------------------------------------------------------------------------------------------------------|------|---|
| Returning from a subroutine within the current code segment:                                                                           | RET  | - |
| Returning from a subroutine within any code segment:                                                                                   | RETS | - |
| Returning from a subroutine within the current code segment plus an additional popping of a selectable register from the system stack: | RETP | - |
| Returning from an interrupt service routine:                                                                                           | RETI | - |

**Table 14-12 System Control Instructions**

|                                                                                                                                                                                                              |        |   |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---|
| Resetting the XC27x5X via software:                                                                                                                                                                          | SRST   | - |
| Entering the Idle mode:                                                                                                                                                                                      | IDLE   | - |
| No function, do not use <sup>1)</sup> :                                                                                                                                                                      | PWRDN  | - |
| Servicing the Watchdog Timer:                                                                                                                                                                                | SRVWDT | - |
| Disabling the Watchdog Timer:                                                                                                                                                                                | DISWDT | - |
| Enabling the Watchdog Timer (can only be executed in WDT enhanced mode):                                                                                                                                     | ENWDT  | - |
| Signifying the end of the initialization routine (switches the register security mechanism to “protected” and disables the effect of any later execution of a DISWDT instruction in WDT compatibility mode): | EINIT  | - |

<sup>1)</sup> Instruction PWRDN is used to enter Power Down mode in previous 16-bit architectures. In the XC27x5X devices, however, PWRDN has no effect and is executed like a NOP instruction.

**Table 14-13 Miscellaneous**

|                                                                                                                         |        |       |
|-------------------------------------------------------------------------------------------------------------------------|--------|-------|
| Null operation which requires 2 Bytes of storage and the minimum time for execution:                                    | NOP    | -     |
| Definition of an unseparable instruction sequence:                                                                      | ATOMIC | -     |
| Switch ‘reg’, ‘bitoff’ and ‘bitaddr’ addressing modes to the Extended SFR space:                                        | EXTR   | -     |
| Override the DPP addressing scheme using a specific data page instead of the DPPs, and optionally switch to ESFR space: | EXTP   | EXTPR |
| Override the DPP addressing scheme using a specific segment instead of the DPPs, and optionally switch to ESFR space:   | EXTS   | EXTSR |

*Note: The ATOMIC and EXT\* instructions provide support for uninterruptable code sequences e.g. for semaphore operations. They also support data addressing beyond the limits of the current DPPs (except ATOMIC), which is advantageous for bigger memory models in high level languages.*

**Instruction Set Summary**
**Table 14-14 MAC-Unit Instructions**

|                            |         |       |
|----------------------------|---------|-------|
| Multiply (and Accumulate): | CoMUL   | CoMAC |
| Add/Subtract:              | CoADD   | CoSUB |
| Shift right/Shift left:    | CoSHR   | CoSHL |
| Arithmetic Shift right:    | CoASHR  | —     |
| Load Accumulator:          | CoLOAD  | —     |
| Store MAC register:        | CoSTORE | —     |
| Compare values:            | CoCMP   | —     |
| Minimum/Maximum:           | CoMIN   | CoMAX |
| Absolute value:            | CoABS   | —     |
| Rounding:                  | CoRND   | —     |
| Move data:                 | CoMOV   | —     |
| Negate accumulator:        | CoNEG   | —     |
| Null operation:            | CoNOP   | —     |

**Protected Instructions**

Some instructions of the XC27x5X which are critical for the functionality of the controller are implemented as so-called Protected Instructions. These protected instructions use the maximum instruction format of 32 bits for decoding, while the regular instructions only use a part of it (e.g. the lower 8 bits) with the other bits providing additional information like involved registers. Decoding all 32 bits of a protected doubleword instruction increases the security in cases of data distortion during instruction fetching. Critical operations like a software reset are therefore only executed if the complete instruction is decoded without an error. This enhances the safety and reliability of a microcontroller system.

**Device Specification**

## 15 Device Specification

The device specification describes the electrical parameters of the device. It lists DC characteristics like input, output or supply voltages or currents, and AC characteristics like timing characteristics and requirements.

Other than the architecture, the instruction set, or the basic functions of the XC27x5X core and its peripherals, these DC and AC characteristics are subject to changes due to device improvements or specific derivatives of the standard device.

Therefore, these characteristics are not contained in this manual, but rather provided in a separate Data Sheet, which can be updated more frequently.

Please refer to the current version of the Data Sheet of the respective device for all electrical parameters.

*Note: In any case the specific characteristics of a device should be verified, before a new design is started. This ensures that the used information is up to date.*

The XC27x5X derivatives are shipped in several packages. The following figures show the basic pin diagrams of the XC27x5X. They show the location of the different supply and IO pins. A detailed description of all the pins and their selectable functions can be found in the corresponding Data Sheet.

*Note: Not all packages shown in the figures are supported by all derivatives.  
Please refer to the corresponding descriptions in the data sheets.*



MC\_XY\_PIN144

**Figure 15-1 Pin Configuration PG-LQFP-144 Package (top view)**



MC\_XY\_PIN100

**Figure 15-2 Pin Configuration PG-LQFP-100 Package (top view)**



**Figure 15-3 Pin Configuration PG-LQFP-64 Package (top view)**

**Keyword Index**

## Keyword Index

This section lists a number of keywords which refer to specific details of the XC27x5X in terms of its architecture, its functional units or functions. This helps to quickly find the answer to specific questions about the XC27x5X.

This User's Manual consists of two Volumes, "System Units" and "Peripheral Units". For your convenience this keyword index refers to both volumes, so you can immediately find the reference to the desired section in the corresponding document ([1] or [2]).

*Note: Registers are listed in a separate index: [Register Index](#).*

### A

Acronyms 1-9 [1]

ADC

Equidistant Sampling **18-106 [2]**

Address Windows (External Bus) 11-9 [1]

Addressing Modes

Code Addressing 5-33 [1]

CoREG Addressing Mode 5-47 [1]

DSP Addressing Modes 5-43 [1]

Indirect Addressing Modes 5-41 [1]

Long Addressing Modes 5-38 [1]

Short Addressing Modes 5-36 [1]

ALU 5-54 [1]

Atomic Instruction 5-8 [1]

### B

Baudrate

Bootstrap Loader 12-25 [1]

Bit

Manipulation 5-58 [1]

Manipulation Instructions 14-2 [1]

protected 2-36 [1]

Protection 5-58 [1]

reserved 2-17 [1]

Block Diagram ITC / PEC 7-4 [1]

Bootstrap Loader 12-18 [1]

Branch Prediction 5-7 [1]

Bus Phases (External Bus) 11-2 [1]

Byte Write Configuration (EBC) 11-19 [1]

### C

C166S-V2 5-1 [1]

CAN

Block diagram 22-1 [2]

Clock control 22-102 [2]

Features 22-2 [2]

Functional description 22-3 [2]

Interrupt structure 22-105 [2]

Module implementation 22-106 [2]

MultICAN

Analysis mode 22-18 [2]

Bit timing 22-9 [2]

Block diagram 22-6 [2]

Error handling 22-11 [2]

Gateway mode 22-41 [2]

Interrupts 22-12 [2]

Message acceptance filtering  
22-21 [2]

Message object FIFO 22-36 [2]

Message object lists 22-13 [2]

Node control 22-9 [2]

Overview 22-4 [2]

Registers

LISTiH **22-57 [2]**

LISTiL **22-58 [2]**

MCR **22-55 [2]**

MITR **22-56 [2]**

MOAMRnH **22-95 [2]**

MOAMRnL **22-95 [2]**

MOARnH **22-97 [2]**

MOARnL **22-98 [2]**

## Keyword Index

- MOCTRnH **22-79 [2], 22-82 [2]**  
MOCTRnL **22-80 [2], 22-82 [2]**  
MODATAnHH **22-101 [2]**  
MODATAnHL **22-101 [2]**  
MODATAnLH **22-100 [2]**  
MODATAnLL **22-100 [2]**  
MOFCRnH **22-89 [2]**  
MOFCRnL **22-91 [2]**  
MOFGPRnH **22-93 [2]**  
MOFGPRnL **22-93 [2]**  
MOIPRnH **22-87 [2]**  
MOIPRnL **22-87 [2]**  
MSIDk **22-60 [2]**  
MSIMASKH **22-61 [2]**  
MSIMASKL **22-61 [2]**  
MSPNDKh **22-59 [2]**  
MSPNDKL **22-59 [2]**  
NBTRxH **22-72 [2]**  
NBTRxL **22-72 [2]**  
NCRx **22-62 [2]**  
NECNTxH **22-73 [2]**  
NECNTxL **22-74 [2]**  
NFCRxH **22-75 [2]**  
NFCRxL **22-76 [2]**  
NIPRx **22-70 [2]**  
NPCRx **22-71 [2]**  
NSRx **22-66 [2]**  
PANCTRH **22-50 [2]**  
PANCTRL **22-50 [2]**
- CAPCOM12  
Capture Mode 19-14 [2]  
Counter Mode 19-9 [2]
- CAPCOM2 2-17 [1]
- Capture Mode  
GPT1 16-27 [2]  
GPT2 (CAPREL) 16-49 [2]
- Capture/Compare Registers 19-11 [2]
- CCU6 2-19 [1]
- Clock  
generation 2-33 [1]  
output signal 8-22 [1]
- Clock System  
Main oscillator 8-4 [1]
- Oscillator run detection 8-14 [1]
- Clock system  
Clock source 8-7 [1]  
Gain control 8-5 [1]  
PLL, see "PLL"
- Concatenation of Timers 16-23 [2],  
16-48 [2]
- Context Switch 5-28 [1]
- Count direction 16-6 [2], 16-37 [2]
- Counter 16-21 [2], 16-46 [2]
- Counter Mode (GPT1) 16-10 [2], 16-41 [2]
- CPU 2-2 [1], 5-1 [1]
- CPU Stack Pointer 5-49 [1]
- D**
- Data Management Unit (Introduction)  
2-9 [1]
- Data Page 5-39 [1]
- Demultiplexed External Bus 11-5 [1]
- Development Support 1-8 [1]
- Direction  
count 16-6 [2], 16-37 [2]
- Division 5-60 [1]
- Double-Register Compare 19-24 [2]
- DPP 5-39 [1]
- DSP Processing 5-62 [1]
- E**
- EBC  
Address Windows 11-9 [1]  
Arbitration 11-13 [1]  
Bus Phases 11-2 [1]  
Byte Write Configuration 11-19 [1]  
Idle State 11-17 [1]  
Interface 11-1 [1]  
Master Slave Connection 11-16 [1]  
Ready Control 11-11 [1]  
Register Description 11-18 [1]  
Shutdown Control 11-24 [1]  
Timing 11-2 [1]
- ESR 8-74 [1]  
ESRx 7-1 [1]  
EXTBUS 11-1 [1]

## Keyword Index

Extend Instruction 5-8 [1]

External

  Bus 2-14 [1]

  Interrupts 7-45 [1]

External Bus 11-1 [1]

External Bus Arbitration 11-13 [1]

### F

Flags 5-53 [1]–5-56 [1]

Flash

  Command Sequences 3-25 [1]

    Change Read Margin 3-27 [1]

    Clear Status 3-27 [1]

    Disable Read Protection 3-34 [1]

    Disable Write Protection 3-35 [1]

    Enter Page Mode 3-28 [1]

    Enter Security Page Mode 3-29 [1]

    Erase Page 3-33 [1]

    Erase Sector 3-32 [1]

    Erase Security Page 3-33 [1]

    Load Page Word 3-30 [1]

    Program Page 3-31 [1]

    Re-Enable Read/Write Protection 3-36 [1]

    Reset to Read 3-27 [1]

Concurrent Program/Erase 3-37 [1]

Definitions 3-19 [1]

  Array 3-20 [1]

  Block 3-20 [1]

  Drain Disturb 3-20 [1]

  Endurance 3-19 [1]

  Erasing 3-19 [1]

  Memory 3-20 [1]

  Page 3-20 [1]

  Programming 3-19 [1]

  Retention 3-19 [1]

  Sector 3-20 [1]

ECC 3-40 [1]

EEPROM Emulation 3-53 [1]

Interrupt Generation 3-55 [1]

Linear Code Pre-Fetch 3-23 [1]

Logical Sectors 3-42 [1]

Margin Reads 3-41 [1]

Operating Modes 3-21 [1]

  Command Mode 3-22 [1]

  Page Mode 3-22 [1]

  Read Mode 3-21 [1]

Protection

  Details 3-44 [1]

  Determining RPA and WPA 3-47 [1]

  Effective Read Security 3-48 [1]

  Effective Write Security 3-48 [1]

  Examples 3-51 [1]

  Lower Layer "Physical State"

  3-45 [1]

  Middle Layer "Flash State" 3-46 [1]

  Overview 3-41 [1]

  Security Pages 3-50 [1]

  Upper Layer "Protection State"

  3-47 [1]

Recommendations

  EEPROM Emulation 3-56 [1]

  Programming Code and Constant Data 3-55 [1]

Recommendations 3-55 [1]

Sequence Errors 3-36 [1]

Wait States 3-23 [1], 3-60 [1]

Fractional divider

  Block diagram 22-108 [2]

  Operating modes 22-110 [2]

  Suspend mode 22-111 [2]

Frequency

  output signal 8-22 [1]

### G

Gated timer mode (GPT1) 16-9 [2]

Gated timer mode (GPT2) 16-40 [2]

GPRs

  General Purpose Registers 5-24 [1]

GPT 2-20 [1]

  GPT1 16-2 [2]

  GPT2 16-33 [2]

### I

Idle State (External Bus) 11-17 [1]

## Keyword Index

- IMB 3-57 [1]
  - Block Diagram 3-57 [1]
  - Error Reporting Summary 3-74 [1]
  - Overview 3-57 [1]
  - Registers
    - Overview 3-59 [1]
- Incremental Interface Mode (GPT1)
  - 16-11 [2]
- Instruction 14-1 [1]
  - Bit Manipulation 14-2 [1]
  - Pipeline 5-9 [1]
  - Pointer 5-34 [1]
  - protected 14-6 [1]
- Interface
  - External Bus 11-1 [1]
- Interrupt
  - External 7-45 [1]
  - Latency 7-48 [1]
  - Priority 7-9 [1]
  - RTC 17-13 [2]
  - System 2-8 [1], 7-3 [1]
- IO Area
  - CPU Pipeline behaviour **5-10 [1]**
- L**
  - Latency
    - Interrupt, PEC 7-48 [1]
  - LXBUS 11-1 [1]
  - LXBus 2-14 [1]
- M**
  - MAC Unit 5-62 [1]
  - Master Slave Connection (EBC) 11-16 [1]
  - MCHK
    - Functionality 4-2 [1]
    - LFSR 4-2 [1]
    - Linear Feedback Shift Register 4-2 [1]
    - MISR 4-6 [1]
    - Multiple Input Shift Register 4-6 [1]
  - Memory 2-10 [1], 3-1 [1]
    - Address Space Overview 3-1 [1]
    - CPU behavior when accessing IO Area **5-10 [1]**
- Data Retention Memories 3-76 [1]
- Data SRAM (DSRAM) 3-10 [1]
- Dual-Port RAM (DPRAM) 3-10 [1]
- External Memory Space 3-17 [1]
- Flash 3-14 [1], **3-19 [1]**
- Flash Emulation 3-13 [1]
- IMB 3-57 [1]
- IO Areas 3-16 [1]
- Little Endian 3-2 [1]
- Marker Memory (MKMEM) 3-11 [1]
- Memory Map 3-3 [1]
- On-Chip Program Memory Map 3-12 [1]
- Program/Data SRAM (PSRAM) 3-13 [1]
- Register Areas 3-5 [1]
- System Stack 3-15 [1]
- Memory Checker
  - Functionality 4-2 [1]
  - LFSR 4-2 [1]
  - Linear Feedback Shift Register 4-2 [1]
  - MISR 4-6 [1]
  - Multiple Input Shift Register 4-6 [1]
- MPU
  - Registers Overview 6-3 [1]
- Multiplexed External Bus 11-6 [1]
- Multiplication 5-60 [1]
- N**
  - Non-Segmented Mode 5-33 [1]
- O**
  - OCDS
    - Requests 7-47 [1]
- P**
  - PD+ Bus
    - Bit Protection 5-58 [1]
  - PEC 2-10 [1]
    - Latency 7-48 [1]
  - Peripheral
    - Summary 2-15 [1]
  - Pins 10-1 [1]

## Keyword Index

Pipeline 5-9 [1]  
**PLL 8-6 [1]**  
    Functionality 8-6 [1]  
    Switching parameters 8-15 [1]  
**Port 2-31 [1]**  
    Temperature compensation 8-169 [1]  
**Ports**

    Configuring a Pin 9-14 [1]  
    Output register Pn\_OUT 9-9 [1]  
    Pad driver control 9-6 [1]  
    Structure  
        Analog 9-4 [1]  
        Hardware Override 9-3 [1]  
        Standard 9-2 [1]

**Prefetch 5-5 [1]**  
**Program Management Unit (Introduction)**  
    2-9 [1]

**Protected**  
    Bits 2-36 [1]  
    instruction 14-6 [1]

## R

**Ready Control (External Bus) 11-11 [1]**  
**Real Time Clock (->RTC) 2-22 [1], 17-1 [2]**

**Registers**  
    EBC 11-18 [1]

**Reserved bits 2-17 [1]**

**Reset 8-54 [1]**  
    Module behavior 8-62 [1]

**RTC 2-22 [1], 17-1 [2]**

    Registers  
        T14 17-8 [2]  
        T14REL 17-8 [2]

## S

**Segmented Mode 5-33 [1]**  
**Shutdown Control (EBC) 11-24 [1]**  
**System Stack 5-49 [1]**

## T

**Temperature compensation 8-169 [1]**  
**Timer 16-2 [2], 16-33 [2]**  
    Auxiliary Timer 16-15 [2], 16-42 [2]

Concatenation 16-23 [2], 16-48 [2]  
Core Timer 16-4 [2], 16-35 [2]  
Counter Mode (GPT1) 16-10 [2],  
16-41 [2]  
Gated Mode (GPT1) 16-9 [2]  
Gated Mode (GPT2) 16-40 [2]  
Incremental Interface Mode (GPT1)  
16-11 [2]  
Mode (GPT1) 16-8 [2]  
Mode (GPT2) 16-39 [2]  
Timing (External Bus) 11-2 [1]  
Tools 1-8 [1]

## U

### USIC

ASC mode 21-110 [2]  
Automatic shaping 21-118 [2]  
Baud rate 21-116 [2]  
Bit timing 21-115 [2]  
Collision detection 21-116 [2]  
Data transfer interrupts 21-120 [2]  
EOF control 21-118 [2]  
Frame format 21-111 [2]  
Noise detection 21-116 [2]  
Protocol interrupts 21-119 [2]  
Protocol registers 21-123 [2]  
Pulse shaping 21-117 [2]  
Receive buffer 21-121 [2]  
Signals 21-110 [2]  
Sync-break detection 21-121 [2]  
Transfer status 21-121 [2]

Baud rate 21-8 [2]  
Channel structure 21-5 [2]  
Data buffer 21-10 [2]  
Data shifting and handling 21-9 [2]  
Data transfer interrupts 21-21 [2]  
External frequency 21-41 [2]  
Feature set 21-2 [2]  
FIFO buffer 21-11 [2]  
FIFO data buffer 21-79 [2]  
Fractional divider 21-41 [2]  
General interrupts 21-20 [2]  
IIC mode 21-161 [2]

**Keyword Index**

- Baud rate 21-166 [2]
- Byte stretching 21-166 [2]
- Data bit symbol 21-173 [2]
- Data flow handling 21-174 [2]
- Frame format 21-164 [2]
- Master arbitration 21-166 [2]
- Master transmission 21-178 [2]
- Mode control 21-167 [2]
- Protocol interrupts 21-168 [2]
- Protocol registers 21-179 [2]
- Receiver address acknowledge 21-169 [2]
- Receiver handling 21-169 [2]
- Receiver status 21-170 [2]
- Signals 21-162 [2]
- Start symbol 21-172 [2]
- Stop symbol 21-173 [2]
- Symbol timing 21-171 [2]
- Transmission chain 21-166 [2]
- Transmit data 21-174 [2]
- IIS mode 21-185 [2]
  - Baud rate 21-194 [2]
  - Connection of Audio devices 21-188 [2]
  - Data interrupts 21-192 [2]
  - Frame and word length 21-189 [2]
  - Mode control 21-189 [2]
  - Protocol interrupts 21-197 [2], 21-198 [2]
  - Protocol overview 21-187 [2]
  - Protocol registers 21-199 [2]
  - Receive data 21-193 [2]
  - Signals 21-185 [2]
  - Slave mode operation 21-198 [2]
  - Transfer delay 21-187 [2], 21-190 [2]
  - Transmit data 21-192 [2]
  - WA generation 21-195 [2], 21-196 [2]
- Implementation
  - Address map 21-207 [2]
  - Channels 21-206 [2]
  - I/O lines of USIC0 21-213 [2]
- I/O lines of USIC1 21-216 [2]
- I/O lines of USIC2 21-219 [2]
- I/O lines of USIC3 21-222 [2]
- Interrupt registers 21-210 [2]
- Overview 21-205 [2]
- Input stages 21-6 [2], 21-36 [2]
- Kernel registers
  - Baud rate registers 21-46 [2]
  - BRGH 21-50 [2]
  - BRGL 21-48 [2]
  - BYP 21-89 [2]
  - BYPCRH 21-91 [2]
  - BYPCRL 21-89 [2]
  - CCFG 21-28 [2]
  - CCR 21-25 [2]
  - Channel control and configuration registers 21-25 [2]
  - Data buffer registers 21-69 [2]
  - DX0CR 21-38 [2]
  - DX1CR 21-38 [2]
  - DX2CR 21-38 [2]
  - FDRH 21-47 [2]
  - FDRL 21-46 [2]
  - FIFO buffer and bypass registers 21-89 [2]
  - FMRH 21-68 [2]
  - FMRL 21-67 [2]
  - INPRH 21-32 [2]
  - INPRL 21-31 [2]
  - Input stage register 21-38 [2]
  - INx 21-105 [2]
  - KSCFG 21-29 [2]
  - OUTDRH 21-107 [2]
  - OUTDRL 21-107 [2]
  - OUTRH 21-106 [2]
  - OUTRL 21-106 [2]
  - Overview 21-14 [2]
  - PCRH 21-33 [2], 21-126 [2], 21-154 [2], 21-179 [2], 21-201 [2]
  - PCRL 21-33 [2], 21-123 [2], 21-152 [2], 21-179 [2], 21-199 [2]
  - Protocol registers 21-33 [2]
  - PSCR 21-35 [2]

**Keyword Index**

- PSR 21-34 [2], 21-127 [2],  
21-156 [2], 21-182 [2], 21-202 [2]
- RBCTRH 21-102 [2]
- RBCTRL 21-101 [2]
- RBUF 21-76 [2]
- RBUF0 21-70 [2]
- RBUF01SRH 21-73 [2]
- RBUF01SRL 21-70 [2]
- RBUF1 21-73 [2]
- RBUFD 21-77 [2]
- RBUFSR 21-78 [2]
- SCTRH 21-59 [2]
- SCTRL 21-57 [2]
- TBCTRH 21-99 [2]
- TBCTRL 21-98 [2]
- TBUFx 21-69 [2]
- TCSRH 21-65 [2]
- TCSRL 21-60 [2]
- Transfer control/status registers  
21-57 [2]
- TRBPTRH 21-109 [2]
- TRBPTRL 21-108 [2]
- TRBSCR 21-96 [2]
- TRBSRH 21-95 [2]
- TRBSRL 21-92 [2]
- Mode control 21-19 [2]
- Module registers
- USIC0\_IDH 21-209 [2]
  - USIC0\_IDL 21-208 [2]
  - USIC1\_IDH 21-209 [2]
  - USIC1\_IDL 21-208 [2]
  - USIC2\_IDH 21-209 [2]
  - USIC2\_IDL 21-208 [2]
  - USIC3\_IDH 21-209 [2]
  - USIC3\_IDL 21-208 [2]
- Output signals 21-7 [2]
- Protocol control and status 21-18 [2]
- Protocol interrupts 21-24 [2]
- Protocol related counter 21-42 [2]
- Receive buffering 21-55 [2]
- Registers overview 21-14 [2]
- SSC mode 21-131 [2]
- Automatic Shadow mechanism
- 21-139 [2]
- Baud rate 21-143 [2]
- Data frame control 21-140 [2]
- EOF control 21-148 [2], 21-151 [2]
- Master mode 21-143 [2]
- Protocol interrupts 21-147 [2],  
21-150 [2]
- Protocol registers 21-152 [2]
- Receive buffer 21-141 [2]
- Signals 21-131 [2]
- Slave mode 21-150 [2]
- Slave select delay 21-146 [2]
- Slave select generation 21-144 [2]
- Time quanta counter 21-44 [2]
- Transmit buffering 21-51 [2]

**W**

- Watchdog 2-30 [1]
- Watchdog Timer 8-173 [1]
- Kernel Registers 8-178 [1]
- Modes of operation
- Disable Mode 8-176 [1]
  - Normal Mode 8-175 [1]
  - Prewarning Mode 8-176 [1]
- Period calculation 8-174 [1]

**Z**

- Zero-Cycle Jump 5-7 [1]

## Register Index

## Register Index

This section lists the registers of the XC27x5X. This helps to quickly find the reference to the description of the respective register.

This User's Manual consists of two Volumes, "System Units" and "Peripheral Units". For your convenience this register index refers to both volumes, so you can immediately find the reference to the desired section in the corresponding document ([1] or [2]).

*Note: Keywords are listed in a separate index: [Keyword Index](#).*

### A

ADC0\_KSCFG 18-24 [2]  
ADCx\_ALR0 18-79 [2]  
ADCx\_ASENR 18-39 [2]  
ADCx\_BWDCFGR 18-116 [2]  
ADCx\_BWDENR 18-115 [2]  
ADCx\_CHCTRx 18-70 [2]  
ADCx\_CHINCR 18-75 [2]  
ADCx\_CHINFR 18-74 [2]  
ADCx\_CHINPRx 18-76 [2]  
ADCx\_CRCRx 18-45 [2]  
ADCx\_CRMRx 18-47 [2]  
ADCx\_CRPRx 18-46 [2]  
ADCx\_EMCTR 18-112 [2]  
ADCx\_EMENR 18-110 [2]  
ADCx\_EVINCR 18-95 [2]  
ADCx\_EVINFR 18-94 [2]  
ADCx\_EVINPRx 18-96 [2]  
ADCx\_GLOBCTR 18-27 [2]  
ADCx\_GLOBSTR 18-29 [2]  
ADCx\_ID 18-26 [2]  
ADCx\_INPRx 18-72 [2]  
ADCx\_LCBRx 18-73 [2]  
ADCx\_Q0Rx 18-59 [2]  
ADCx\_QBURx 18-61 [2]  
ADCx\_QINRx 18-63 [2]  
ADCx\_QMRx 18-54 [2]  
ADCx\_QSRx 18-57 [2]  
ADCx\_RCRx 18-92 [2]  
ADCx\_RESRAVx 18-89 [2]  
ADCx\_RESRAx 18-89 [2]  
ADCx\_RESRVx 18-88 [2]

ADCx\_RESRx 18-88 [2]  
ADCx\_RISRx 18-32 [2]  
ADCx\_RSPRx 18-40 [2]  
ADCx\_RSSR 18-90 [2]  
ADCx\_SYNCTR 18-114 [2]  
ADCx\_VFR 18-91 [2]  
ADDRSEL7 11-28 [1]  
ADDRSELx 11-23 [1]

### C

CAN\_LISTiH 22-57 [2]  
CAN\_LISTiL 22-58 [2]  
CAN\_MCR 22-55 [2]  
CAN\_MITR 22-56 [2]  
CAN\_MOAMRnH 22-95 [2]  
CAN\_MOAMRnL 22-95 [2]  
CAN\_MOARnH 22-97 [2]  
CAN\_MOARnL 22-98 [2]  
CAN\_MOCTRnH 22-79 [2], 22-82 [2]  
CAN\_MOCTRnL 22-80 [2]  
CAN\_MODATAnHH 22-101 [2]  
CAN\_MODATAnHL 22-101 [2]  
CAN\_MODATAnLH 22-100 [2]  
CAN\_MODATAnLL 22-100 [2]  
CAN\_MOFCRnH 22-89 [2]  
CAN\_MOFCRnL 22-91 [2]  
CAN\_MOFGPRnH 22-93 [2]  
CAN\_MOFGPRnL 22-93 [2]  
CAN\_MOIPRnH 22-87 [2]  
CAN\_MOIPRnL 22-87 [2]  
CAN\_MOSTATnL 22-82 [2]  
CAN\_MSIDk 22-60 [2]

## Register Index

CAN\_MSIMASKH 22-61 [2]  
CAN\_MSIMASKL 22-61 [2]  
CAN\_MSPNDkH 22-59 [2]  
CAN\_MSPNDkL 22-59 [2]  
CAN\_NBTRxH 22-72 [2]  
CAN\_NBTRxL 22-72 [2]  
CAN\_NCRx 22-62 [2]  
CAN\_NECNTxH 22-73 [2]  
CAN\_NECNTxL 22-74 [2]  
CAN\_NFCRxH 22-75 [2]  
CAN\_NFCRxL 22-76 [2]  
CAN\_NIPRx 22-70 [2]  
CAN\_NPCRx 22-71 [2]  
CAN\_NSRx 22-66 [2]  
CAN\_PANCTRH 22-50 [2]  
CAN\_PANCTRL 22-50 [2]  
CAPREL 16-58 [2]  
CC2\_CCyIC 19-36 [2]  
CC2\_DRM 19-25 [2]  
CC2\_IOC 19-31 [2]  
CC2\_KSCCFG 17-15 [2], 19-39 [2]  
CC2\_M4/5/6/7 19-11 [2]  
CC2\_OUT 19-27 [2]  
CC2\_SEE 19-29 [2]  
CC2\_SEM 19-29 [2]  
CC2\_T78CON 19-5 [2]  
CC2\_T7IC 19-10 [2]  
CC2\_T8IC 19-10 [2]  
CCU6x\_CC63R 20-64 [2]  
CCU6x\_CC63SR 20-64 [2]  
CCU6x\_CC6xR 20-33 [2]  
CCU6x\_CC6xSR 20-34 [2]  
CCU6x\_CMPMODIF 20-39 [2]  
CCU6x\_CMPSTAT 20-37 [2]  
CCU6x\_IEN 20-98 [2]  
CCU6x\_INP 20-101 [2]  
CCU6x\_IS 20-91 [2]  
CCU6x\_ISR 20-96 [2]  
CCU6x\_ISS 20-94 [2]  
CCU6x\_KSCFG 20-112 [2]  
CCU6x\_KCSR 20-114 [2]  
CCU6x\_MCMOUT 20-87 [2]  
CCU6x\_MCMOUTS 20-86 [2]

CCU6x\_MODCTR 20-78 [2]  
CCU6x\_PISELH 20-109 [2]  
CCU6x\_PISELL 20-107 [2]  
CCU6x\_PSLR 20-83 [2]  
CCU6x\_T12 20-32 [2]  
CCU6x\_T12DTC 20-35 [2]  
CCU6x\_T12MSEL 20-40 [2]  
CCU6x\_T12PR 20-32 [2]  
CCU6x\_T13 20-62 [2]  
CCU6x\_T13PR 20-63 [2]  
CCU6x\_TCTR0 20-41 [2]  
CCU6x\_TCTR2 20-44 [2]  
CCU6x\_TCTR4 20-47 [2]  
CCU6x\_TRPCTR 20-80 [2]  
CP 5-31 [1]  
CPUCON1 5-21 [1]  
CPUCON2 5-22 [1]  
CRIC 16-59 [2]  
CSP 5-34 [1]

**D**

DPP0/1/2/3 5-39 [1]

**E**

EBCMOD0 11-18 [1]  
EBCMOD1 11-20 [1]

**F**

FCONCS7 11-27 [1]  
FCONCSx 11-22 [1]

**G**

GPT12E\_CAPREL 16-58 [2]  
GPT12E\_CRIC 16-59 [2]  
GPT12E\_KSCCFG 16-61 [2]  
GPT12E\_T2,-T3,-T4 16-31 [2]  
GPT12E\_T2/3/4IC 16-32 [2]  
GPT12E\_T2CON 16-15 [2]  
GPT12E\_T3CON 16-4 [2]  
GPT12E\_T4CON 16-15 [2]  
GPT12E\_T5,-T6 16-58 [2]  
GPT12E\_T5/6IC 16-59 [2]  
GPT12E\_T5CON 16-42 [2]

## Register Index

GPT12E\_T6CON 16-35 [2]

**I**

IDX0/1 5-43 [1]  
IMB module registers 3-59 [1]  
IMB\_ECC\_STAT 3-72 [1]  
IMB\_ECC\_TRAP 3-70 [1]  
IMB\_FSR\_BUSY 3-64 [1]  
IMB\_FSR\_OP 3-65 [1]  
IMB\_FSR\_PROT 3-67 [1]  
IMB\_IMBCTRH 3-61 [1]  
IMB\_IMBCTRL 3-60 [1]  
IMB\_INTCTR 3-63 [1]  
IMB\_MAR0 3-68 [1]  
IMB\_PROCONx 3-69 [1]  
IP 5-34 [1]

**M**

MAH 5-67 [1]  
MAL 5-66 [1]  
MCHK\_COUNT 4-18 [1]  
MCHK\_IR 4-15 [1]  
MCHK\_RRH 4-16 [1]  
MCHK\_RRL 4-16 [1]  
MCHK\_TPRH 4-19 [1]  
MCHK\_TPRL 4-19 [1]  
MCW 5-63 [1]  
MDC 5-61 [1]  
MDH 5-60 [1]  
MDL 5-61 [1]  
MPU\_PM0 6-5 [1]  
MPU\_PMx 6-7 [1]  
MPU\_PRA 6-9 [1]  
MPU\_PRD 6-7 [1]  
MPU\_PRLx 6-4 [1]  
MPU\_PRUx 6-4 [1]  
MRW 5-70 [1]  
MSW 5-68 [1]

**O**

ONES 5-72 [1]

**P**

Pn\_DIDIS  
P15 9-16 [1]  
P5 9-16 [1]  
Pn\_IN 9-12 [1]  
Pn\_IOCRx 9-13 [1]  
Pn\_OMRH  
P10 9-10 [1]  
P2 9-10 [1]  
Pn\_OMRL 9-10 [1]  
Pn\_OUT 9-9 [1]  
Pn\_POCON 9-7 [1]  
Ports  
Pn\_IN 9-12 [1]  
Pn\_IOCRx 9-13 [1]  
Pn\_OMR 9-10 [1]  
PSW 5-53 [1]

**Q**

QR0/1 5-42 [1]  
QX0/1 5-44 [1]

**R**

RELH/L 17-10 [2]  
RTC\_CON 17-6 [2]  
RTC\_IC 17-14 [2]  
RTC\_ISNC 17-14 [2]  
RTC\_RELH/L 17-10 [2]  
RTC\_RTCH/L 17-9 [2]  
RTC\_T14 17-8 [2]  
RTC\_T14REL 17-8 [2]  
RTCH/L 17-9 [2]

**S**

SP 5-50 [1]  
SPSEG 5-50 [1]  
STKOV 5-52 [1]  
STKUN 5-52 [1]

**T**

T14 17-8 [2]  
T14REL 17-8 [2]

## Register Index

T2, T3, T4 16-31 [2]  
T2/3/4IC 16-32 [2]  
T2CON 16-15 [2]  
T3CON 16-4 [2]  
T4CON 16-15 [2]  
T5, T6 16-58 [2]  
T5/6IC 16-59 [2]  
T5CON 16-42 [2]  
T6CON 16-35 [2]  
T7IC 19-10 [2]  
T8IC 19-10 [2]  
TCONCS7 11-25 [1]  
TCONCSx 11-21 [1]

**U**

USIC0\_IDH 21-209 [2]  
USIC0\_IDL 21-208 [2]  
USIC1\_IDH 21-209 [2]  
USIC1\_IDL 21-208 [2]  
USIC2\_IDH 21-209 [2]  
USIC2\_IDL 21-208 [2]  
USIC3\_IDH 21-209 [2]  
USIC3\_IDL 21-208 [2]  
UxCy\_BRGH 21-50 [2]  
UxCy\_BRGL 21-48 [2]  
UxCy\_BYP 21-89 [2]  
UxCy\_BYPCRH 21-91 [2]  
UxCy\_BYPCRL 21-89 [2]  
UxCy\_CCFG 21-28 [2]  
UxCy\_CCR 21-25 [2]  
UxCy\_DX0CR 21-38 [2]  
UxCy\_DX1CR 21-38 [2]  
UxCy\_DX2CR 21-38 [2]  
UxCy\_FDRH 21-47 [2]  
UxCy\_FDRL 21-46 [2]  
UxCy\_FMRH 21-68 [2]  
UxCy\_FMRL 21-67 [2]  
UxCy\_INPRH 21-32 [2]  
UxCy\_INPRL 21-31 [2]  
UxCy\_INx 21-105 [2]  
UxCy\_KSCFG 21-29 [2]  
UxCy\_OUTDRH 21-107 [2]  
UxCy\_OUTDRL 21-107 [2]

UxCy\_OUTRH 21-106 [2]  
UxCy\_OUTRL 21-106 [2]  
UxCy\_PCRH 21-33 [2], 21-126 [2],  
21-154 [2], 21-179 [2], 21-201 [2]  
UxCy\_PCRL 21-33 [2], 21-123 [2],  
21-152 [2], 21-179 [2], 21-199 [2]  
UxCy\_PSCR 21-35 [2]  
UxCy\_PSR 21-34 [2], 21-127 [2],  
21-156 [2], 21-182 [2], 21-202 [2]  
UxCy\_RBCTRH 21-102 [2]  
UxCy\_RBCTRL 21-101 [2]  
UxCy\_RBUF 21-76 [2]  
UxCy\_RBUF0 21-70 [2]  
UxCy\_RBUF01SRH 21-73 [2]  
UxCy\_RBUF01SRL 21-70 [2]  
UxCy\_RBUF1 21-73 [2]  
UxCy\_RBUFD 21-77 [2]  
UxCy\_RBUFSR 21-78 [2]  
UxCy\_SCTRH 21-59 [2]  
UxCy\_SCTRL 21-57 [2]  
UxCy\_TBCTRH 21-99 [2]  
UxCy\_TBCTRL 21-98 [2]  
UxCy\_TBUFx 21-69 [2]  
UxCy\_TCSRH 21-65 [2]  
UxCy\_TCSRL 21-60 [2]  
UxCy\_TRBPTRH 21-109 [2]  
UxCy\_TRBPTRL 21-108 [2]  
UxCy\_TRBSCR 21-96 [2]  
UxCy\_TRBSRH 21-95 [2]  
UxCy\_TRBSRL 21-92 [2]

**Z**

ZEROS 5-72 [1]

[www.infineon.com](http://www.infineon.com)

B158-H9254-G1-X-7600

Published by Infineon Technologies AG